腾讯笔试 完整题目+答案 第二题 太难了

1.0 0.2 1.0 1.0 1.0
第一题:


代码:
思路就是 1.分别 求盒子的 奇数a1和偶数b1   钥匙的奇数a2和偶数b2
2.结果为:min(a1,b2)+min(a2,b1) 奇数盒子所能开的最大数量+ 偶数盒子所能开的最大数量
第二题:
题目:

测试用例:

代码:成功骗了0.2
package tenxun.排队;
import java.util.Scanner;
 /**
 * @author MuChengFeng on 2019/9/1
 */
public class Main {
    public static void main(String[] args) {
        Scanner scan=new Scanner(System.in);
        int n=scan.nextInt();
        if(n==2){
            System.out.println(3);
        }else {
            System.out.println(6);
        }
    }
}


第三题

测试用例:

代码:
#include <cstdio>
using namespace std;

typedef long long ll;

int a[100050];
int n, m, t;
ll sum, k;
bool cal(ll x) {
    sum = 0;
    k = m;
    for(int i = 1; i <= t; i++) {
        sum += a[i];
        while (sum + i >= x) {
            sum -= x - i;
            if (--k < 0) return false;
        }
    }
    return k == 0 ? sum <= 0 : true;
}
int main() {
    scanf("%d %d", &n, &m);
    for(int i = 1; i <= n; i++) {
        scanf("%d", &a[i]);
        sum += a[i];
        if(a[i]) t = i;
    }
    ll l = t + 1, r = sum + t;
    while (l <= r) {
        ll mid = (l + r) / 2;
        if (cal(mid)) r = mid - 1;
        else l = mid + 1;
    }
    printf("%lld\n", l);
}

第四题:
题目:

测试用例:

代码:
#include <cstdio>
#include <algorithm>
using namespace std;

typedef long long ll;
const int N = 100005;
int n, h[N], st[N], top, l[N], r[N];
ll sum[N];

int main() {
    while (~scanf("%d", &n)) {
        top = 0;
        for(int i = 0; i < n; ++i) {
            scanf("%d", h + i);
            sum[i + 1] = sum[i] + h[i];
            while(top > 0 && h[st[top - 1]] >= h[i]) --top;
            l[i] = top == 0 ? 0 : st[top - 1] + 1;
            st[top++] = i;
        }
        top = 0;
        for(int i = n - 1; i >= 0; --i) {
            while(top > 0 && h[st[top - 1]] >= h[i]) --top;
            r[i] = top == 0 ? n : st[top - 1];
            st[top++] = i;
        }
        long long ans = 0;
        for(int i = 0; i < n; ++i) ans = max(ans, (long long)h[i] * (sum[r[i]] - sum[l[i]]));
        printf("%lld\n", ans);
    }
    return 0;
}


第五题:
题目:

测试用例:

代码:
#include <cstdio>
#include <iostream>
using namespace std;

typedef long long ll;
const int N = 100000;
ll dp[N+5][2];
ll sum[N+5];
const int mod = 1e9 + 7;

void init(int k) {
    dp[0][0] = 1;
    for (int i = 1; i <= N; i++) {
        dp[i][0] = (dp[i-1][0] + dp[i-1][1]) % mod;
        for (int j = k; j <= i; j += k) dp[i][1] = (dp[i][1] + dp[i-j][0]) % mod;
        sum[i] = (sum[i-1] + dp[i][0] + dp[i][1]) % mod;
    }
}

int main() {
    int k, n;
    scanf("%d %d", &n, &k);
    init(k);
    while (n--) {
        int a, b;
        scanf("%d %d", &a, &b);
        printf("%lld\n", (sum[b] - sum[a - 1] + mod) % mod);
    }
    return 0;
}



#腾讯##笔试题目##笔经##题解#
全部评论
楼主能说下搬箱子思路吗,看不懂代码。。。
6 回复 分享
发布于 2019-09-02 00:00
第二题做差排个序就好了呀
点赞 回复 分享
发布于 2019-09-01 23:49
大佬,第三题,check的思路是啥呀
点赞 回复 分享
发布于 2019-09-02 08:58
🤣  这都是什么题啊   造飞机啊
点赞 回复 分享
发布于 2020-05-09 19:47
第三题第14行,为什么是大于等于,不应该是大于吗?
点赞 回复 分享
发布于 2019-09-15 11:28
第二题暴力回溯 public static void main(String[] args) {         Scanner scanner = new Scanner(System.in);         int n = scanner.nextInt();         Person[] queue = new Person[n];         for (int i = 0; i < n; i++) {             queue[i] = new Person(scanner.nextInt(), scanner.nextInt());         }         best = Integer.MAX_VALUE;         gen(queue, n, 0, 0);         System.out.println(best);     }     private static int best = 0;          private static void gen(Person[] list, int n, int level, int cs) {         boolean isEnd = true;         for (int i = 0; i < n; i++) {             // 没有访问就访问             if (!list[i].isVisited) {                 isEnd = false;                 list[i].isVisited = true;                 int c = list[i].a * level + list[i].b * (n - level - 1);                 cs += c;                 gen(list, n, level + 1, cs);                 cs -= c;                 list[i].isVisited = false;             }         }         if (level ==n && isEnd && cs < best) best = cs;     }
点赞 回复 分享
发布于 2019-09-08 20:25
话说   你们这图是怎么截下来的?
点赞 回复 分享
发布于 2019-09-02 15:40
第四题的图在这:
点赞 回复 分享
发布于 2019-09-02 14:58
public class Main{ public static void main(String[] args){         Scanner sc = new Scanner(System.in);   int n = sc.nextInt();  int[][] myd = new int[n][2];   for(int i = 0; i < n; i++){             myd[i][0] = sc.nextInt();  myd[i][1] = sc.nextInt();  }         TreeMap px = new TreeMap<Integer,Integer>(new Comparator<Integer>(){ @Override  public int compare(Integer o1, Integer o2){ return o1.compareTo(o2);  }         });   for(int i = 0; i < n; i++){             px.put(i,myd[i][0]-myd[i][1]);  } int min = 0;  Set<Integer> keySet = px.keySet();  Iterator it = keySet.iterator();  int count = 0;  while(it.hasNext()){ int key = Integer.parseInt(it.next().toString());  min += myd[key][0]*count + myd[key][1]*(n-(count+1));  count++;  }         System.out.println(min);   } } 满意度那个 我是这样做的
点赞 回复 分享
发布于 2019-09-02 14:28
你好请问第五题思路可以说一下吗
点赞 回复 分享
发布于 2019-09-02 11:16
除了第三题没什么确定思路外,只能想到暴力模拟呀,其他的都可以。第二题就是键值a-b排个序
点赞 回复 分享
发布于 2019-09-02 10:02
大佬第四题的题目是不是贴错了?是学习效率那个吧?
点赞 回复 分享
发布于 2019-09-02 09:53
大佬 摆花那题的思路是什么啊
点赞 回复 分享
发布于 2019-09-02 09:51
被下面大佬点播发现,第一个人把a,b带入公式居然就与j无关。同理第二个人代入公式也是与j无关。
点赞 回复 分享
发布于 2019-09-02 09:51
偷楼主的图发个帖,感谢楼主
点赞 回复 分享
发布于 2019-09-02 09:44
第五题,你过了吗,题目上没说要取模啊
点赞 回复 分享
发布于 2019-09-02 09:27
第二题不是排个序就出来咯 ,
点赞 回复 分享
发布于 2019-09-02 08:21
确实厉害👍
点赞 回复 分享
发布于 2019-09-02 08:00
点赞 回复 分享
发布于 2019-09-02 01:18
import java.util.ArrayList; import java.util.Collections; import java.util.List; import java.util.Scanner; public class TG2 {     public static void main(String[] args) {         Scanner in = new Scanner(System.in);         String cc = in.nextLine();         int m = Integer.parseInt(cc);         List<String[]> list = new ArrayList<>();         for (int i = 0; i < m; i++) {             list.add(in.nextLine().split(" "));         }         int ans = 0;         List<Integer> list1 = new ArrayList<>();         for (int i =0;i<m;i++){             int a = Integer.parseInt(list.get(i)[0]);             int b = Integer.parseInt(list.get(i)[1]);             list1.add(a-b);             ans +=b*m-a;         }         Collections.sort(list1);         for (int i =0;i<m;i++){             ans+=list1.get(i)*(m-i);         }         System.out.println(ans);     } }
点赞 回复 分享
发布于 2019-09-02 00:01

相关推荐

2025-12-27 16:21
已编辑
门头沟学院 Java
bg:中下211本科,java后端,无竞赛,无基础,大一升大二暑假开始学java。五段实习:美团-小红书-腾讯-淘天-字节。面秋招的简历只有美团、小红书、淘天。刚刚发现我的秋招蚂蚁流程挂了,这是我最后一个流程,那么我的秋招就算彻底结束了,总结一下:字节ssp+,职级2-1。美团ssp,+2打了半小时微信电话极力挽留。快手ssp,但报了字节薪资后没有争取的想法了。小红书sp,今年小红书给的很高,但比字节2-1还是差很多。虾皮应该是小sp?对虾皮一点意向都没,纯拿来集邮了。淘天ssp(暑期转正),说不要我的三方,毕业前考虑好了随时可以不签三方选择淘天。挂了的流程:京东二面挂,估计学历被卡了。懂车帝一面挂,和面试官聊不来,不认同我的方案。拼多多hr面挂,问我低于预期还来不来,当时说不考虑了,估计觉得我不忠诚。蚂蚁hr面挂,聊的还行,但估计我不会去给我挂了吧。阿里控股一面挂,没面前就知道是kpi了,因为时间可选的很多,而且都是半小时,我也拿他刷我的kpi了。上面差不多是我的情况,下面是我想说的话。我觉得我不算特别突出优秀的那类人,但我多少也算是靠前的那一批人,即使这样,秋招也不算特别顺利,也有挂了的流程,但你能说是我的问题吗,我觉得大部分情况不是的,如果真的是我的问题,我不可能本科校招拿到2-1,所以很多面试挂了,问题不出在面试者身上,很多是看运气+眼缘+和面试官合不合得来。所以我觉得,学会察言观色,了解面试官的脾性,也是面试很重要的一个点。比如面试官是喜欢听长回答,还是听短回答,他更看重哪些点,每个面试官对这些的侧重都是不一样的,所以作为面试者,要学会察言观色,通过面试官开局的一两个问题以及你回答后他的表现,就要判断出来。像我现在其实面试开局个五分钟,我就基本能判断个七七八八了,然后我后面的回答就会有所变化。这是我想说的第一个点:不要为面试结果焦虑,有时候问题不出在你身上,但你可以学一些面试技巧,尽量提高你的面试通过率,这里说的面试技巧指的不是网上那种烂大街的,一两分钟短视频说什么提高你面试通过率的,而是你要在你自己的面试过程中不断总结经验,吸取教训,旁人教你的终究是有限的。另外想说下选offer的事,上面其实可以看出来,我秋招最后是选了字节的,还没签三方我就来提前实习感受业务了,当我签完三方又过了一个多月,我这些天又在想这个问题,字节真的是我想要的吗,我现在总结了一下字节的好坏,发现当时可能被字节的高薪资影响判断了,如果现在再选一次的话,我应该会选杭州的小红书,会生活的更舒服点。具体种种就不展开说了。然后虽然我现在也可以说去把小红书舔回来,去毁字节,但我觉得没必要这么做,我可以采用其他的措施去不就,比如规划好两年内就跳槽,跳到杭州,跳到更舒适的城市。我觉得大家选offer的时候,真的可以冷静下来多方面考虑,薪资、城市、组内氛围、业务、老板是否看重、组内情况、未来升职机会等等都是可以考虑的因素,虽然有的时候不管选哪个,都不会坏,但最好也别让自己后悔吧,即使真后悔了,我觉得也没必要过度美化没走过的路,想好补救措施即可。这是我想说的第二个点:冷静好好做选择,不管是offer还是其他。但人生容错率很大,即使选错了,也一定有补救措施。最后还想说一些成长上的东西,尤其是现在AI火热的时代。我觉得大家如果想提高自己,或者说在未来社招跳槽有竞争力,肯定是要学AI相关的东西的,不说要会多懂AI,至少也要了解基本概念,而且一定要学会用AI提效。我现在字节的mt和我说,他现在80%代码都是AI写的。而我最近也开始尝试用AI工具,感觉现在AI真的进步很多,挺聪明的了,我现在写需求基本都是先让AI写,我再人工review小改动一下就差不多了。我觉得「AI取代程序员」是个很远的话题,但是「AI取代不会用AI的程序员」,可能真的就是近两年的事了。而怎么去学习这块的内容,其实我也正在探索,我也是刚学AI的起步阶段,我觉得大家也要有自己的信息检索能力,而不是别人喂你什么,你才学什么,自己一个人就不会学了。这是我想说的第三个点:趁年轻,多学习提升自己,拥抱AI,不要原地踏步,原地踏步的程序员最容易被淘汰。大概就是这样吧,今天看蚂蚁流程发现挂了,前几天腾讯约面我也拒了,就想到自己的秋招/校招算彻底结束了,有感而发,随便聊了下。牛客以后应该不会更新,大家不用关注,熟悉我的朋友应该知道我在其他平台有号。我更喜欢以长视频的形式去做分享,感觉会更有体系,而不是网上那种一两分钟的零碎短视频的那种营销号去起号,我也推荐大家多去看高质量的长文章、长视频,我觉得收获的能更多。希望大家能收获满意的offer与未来。
CEXBB:刷到最后才发现原来是优雅✌🏻,我的Java引路人
2025年终总结
点赞 评论 收藏
分享
评论
21
287
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务