微策略0929笔试

第一题

有两个玩家,并且有一个大小为n的数字序列。玩家轮流轮换n轮。每一轮,玩家都会从序列中删除第一个数字,并将其值添加到他们的分数中。之后,如果'removed' 数字是偶数,则剩余的序列将反转。确定赛后两名玩家之间的分数差异

更准确地说,假设 first score 和second score 分别计算第一和第二玩家的最终分数。目标是计算 first score-second score的值。

package com.面试中的算法.微策略;

import org.json.JSONObject;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

public class Main2 {
    public static void main(String[] args) {
        String json1 = "{\"hello\":\"world\",\"hi\":\"there\",\"you\":\"me\"}";
        String json2 = "{\"hello\":\"world\",\"hi\":\"hello\",\"you\":\"me\"}";

        List<String> differingKeys = findDifferingKeys(json1, json2);
        System.out.println(differingKeys);
    }

    public static List<String> findDifferingKeys(String json1, String json2) {
        JSONObject jsonObject1 = new JSONObject(json1);
        JSONObject jsonObject2 = new JSONObject(json2);

        List<String> differingKeys = new ArrayList<>();

        for (String key : jsonObject1.keySet()) {
            if (jsonObject2.has(key) && !jsonObject1.get(key).equals(jsonObject2.get(key))) {
                differingKeys.add(key);
            }
        }

        Collections.sort(differingKeys);
        return differingKeys;
    }
}

第二题

实现一个简单的原型服务,以查找两个JSON(lavaScript Object Notation)对象之间的差异。

为了保持原型的简单性,JSON 将仅包含键值对,其中不包含嵌套对象或数组。给定两个JSON 字符串 son1和json2,查找值不同的键列表。如果键仅存在于其中一个 JSON 中,则结果中不应考虑该键。键列表应按字典升序排序。

例:

假设 json1 =“{"你好":"世界”,“嗨”:"你好“,"你“:"我”}”和 json2=“{"你好":"世界“,“嗨”:“你好”,“你”:"我””

值唯一不同的公共键是“hi”。因此答案是[“hi"。

package com.面试中的算法.微策略;

import java.util.Arrays;
import java.util.Collections;
import java.util.LinkedList;
import java.util.List;

public class Main1 {
    public static void main(String[] args) {
        List<Integer> numSeq = new LinkedList<>(Arrays.asList(3, 6, 2, 3, 5));
        System.out.println(calculateScoreDifference(numSeq));
    }

    public static int calculateScoreDifference(List<Integer> numSeq) {
        int firstScore = 0;
        int secondScore = 0;
        boolean isFirstPlayerTurn = true;

        while (!numSeq.isEmpty()) {
            // 删除第一个数字并将其值添加到当前玩家的分数中
            int removed = numSeq.remove(0);

            if (isFirstPlayerTurn) {
                firstScore += removed;
            } else {
                secondScore += removed;
            }

            // 如果删除的数字是偶数,则反转剩余的序列
            if (removed % 2 == 0) {
                Collections.reverse(numSeq);
            }

            // 交替进行操作
            isFirstPlayerTurn = !isFirstPlayerTurn;
        }

        return firstScore - secondScore;
    }
}
#你都收到了哪些公司的感谢信?#
全部评论
你好 请问是只有两道编程题吗
点赞 回复 分享
发布于 09-30 13:48 上海
是海笔嘛
点赞 回复 分享
发布于 10-09 18:50 四川
宝子,测评的Assessment Id:在哪看呀,我好像没收到
点赞 回复 分享
发布于 10-11 09:32 安徽

相关推荐

11-08 19:45
已编辑
西北工业大学 后端
说实话确实有点敷衍一上来英语自我介绍,留学生直接闭着眼睛答然后英语八股文,我之前看别人的帖子以为是中文八股文,没准备英文的。但是作为留学生还是问题不大第一题什么内存泄漏,我说了一句,不让我说了第二题说一下jvm的垃圾回收算法,英语答出来了,基本全对第三题说一下线程和进程的区别,英语答出来了,说了一下主要区别以上一共15分钟然后直接共享屏幕,做一道编程题,但是是让我用自己的ide,题目是java输入输出,自己定义一个树,子树数量不定,自定义输入输出格式,进行文件读写,然后对树进行输入和输出。这种文件读写的题目不难,就是容易出bug,输入输出不一致,而且会写的很长,一百多行代码。我用bfs搞了半天,一堆bug,最后一共做了50分钟,做出来了。面试官也没有提示,不知道在干啥,可能玩手机,感觉再做半小时可能都不会打断我。然后做完之后叫我讲一下思路,我讲完了,他说嗯。然后问时间复杂度是多少?我分析了一下说On2,他说嗯。然后问空间复杂度是多少?我说On,他说嗯然后就说,那么今天的面试就到这里了。我说好的,还没说谢谢,直接挂电话了。不知道啥意思,该不会是kpi面试吧,一般不都是有反问环节吗,我看这家公司(微策略)之前的面经也是有反问环节的。我反正该做的都做了,问的问题也全部答出来了,英语说的也好,手撕也A出来了,不给我二面我也没办法,说明人招满了------------------------后续:直接机翻感谢信,和欧洲写的格式一模一样。只能说确实不招人了,浪费时间,从态度早就可以看出来
查看6道真题和解析
点赞 评论 收藏
分享
投递Momenta等公司10个岗位 > 秋招joker 简历被挂麻了,求建议
点赞 评论 收藏
分享
4 6 评论
分享
牛客网
牛客企业服务