中国银行编程评测

11.17
第二批中国银行编程评测,一共5道编程题,2小时时间。前3道比较简单,后面两道有点绕,不过我全ac了。

 我有印象的几道题:

😺给定n(1<=n<=1e9),问是否存在一对(x,y),满足(x^y)*y + (y^x)*x=n,1<=x,y<=1e9。

解答:让x=1,那么(x^y)*y + (y^x)*x=2y,即n为偶数时有解(1,n/2);而x和y取任意数,这个式子都是偶数,所以直接判断n是否为偶数就行了。

return (n&1) ? "No" : "Yes";

😺给定一个数组a, 长度为n,数组中每个元素范围是[0,n]。定义“好数对(i,j)”为:i*2<=j 且 i!=j 且 a[i] xor a[j]==0。求好数对的数量:

解答:a[i] xor a[j]==0 等价于a[i]==a[j]。从头往后枚举j,维护前j/2个元素各出现了几次即可,复杂度O(n)

😺给定两个排列a和b,长度为n(1<=n<=1e5)。可以交换a中相邻的两个元素。交换后,要让 sum abs(a[i]-b[i])最大,问最少交换几次。

解答:当n为偶数时,sum abs(a[i]-b[i])最大的情况,就是a里面1~n/2的所有元素都对应着b里面n/2+1~n的所有元素。所以让a数组里面<=n/2的给个0标签,>n/2的给个1标签,b数组同理,只需要让a交换后和b的标签对应就好了。计算要交换多少次,只需要计算a中0标签与b中0标签的各个距离之和即可,可以O(n)实现。

当n为奇数时,有个复杂的地方是,元素(n+1)/2既可以给0标签,也可以给1标签。因此就这两种情况都计算一下,取一个交换次数最小值即可。复杂度O(n).

#中国银行测评#
全部评论

相关推荐

牛客76783384...:字节:不要放箭,活捉赵子龙
点赞 评论 收藏
分享
2025-12-13 21:01
已编辑
百度_meg_前端开发(实习员工)
走到这一步,确实有些意外。先简单说说我的情况,我是双非本,大一那年对后端兴趣特别浓,学了快一年半。但不知为什么越往后学兴趣越淡——大概到分布式那块,比如nacos、卡夫卡这些,感觉越来越吃力。再加上看到师兄师姐在后端方向上的碰壁(现在是大go时代),在和师兄师姐商量后我在今年一月左右转前端了或许是因为有java的基础,对项目开发流程有些概念,前端三件套我过得比较快。之后学了Vue,动手做了自己的博客,这大概也是我转前端的一个重要原因吧,一直很想拥有一个属于自己的个人博客,能按自己的想法去设计、实现,并长期迭代完善,这种成就感真的很棒。之前拿过别人的开源项目来更改 但是自己修改的就是一坨,那个时候缺少对前端代码的理解 就算借助ai做出来的效果也是一坨就这样到了大二暑假,我觉得该找份实习,丰富一下简历了。我自认不是很有创造力的人,平时少有自发的项目灵感,所以更希望通过实习开阔眼界、提升能力。一开始投递和面试的过程挺煎熬的,或许是因为目标多是中小厂,很多hr已读不回,或是直接砍半薪资问我接不接受。面试时也常觉得像在走流程,问的都是八股文,有的面试官还会边看题边问,甚至有一次十分钟就结束了,好在最后钛动给了我机会。实习期间我学到了很多,虽然也常被拷打,还好ld会帮我收拾烂摊子。从钛动离职回校后,我半推半就地背八股、学新技术,无聊时就刷里扣、看看牛客和biss。原本以为双非bg很会被hr速度筛掉所以就尝试性的投了纷享销客和百度的日常实习,没想到最后两家都oc了,雷姆了家人们,双非鼠鼠居然圆了大厂梦yysy,这一路其实冒了不小的风险。毕竟学了那么久的后端,大学四年时间有限,突然转前端,意味着很多积累的知识可能用不上了。但我很庆幸当时有放下的勇气。无论过去做了什么选择,我都想感谢当时的自己,因为那份勇气,才走到了今天。同时也很感谢这一路师兄师姐的帮忙,师兄帮忙模拟面试,提供资料,师姐教我如何选择岗位,如何处理实习带来的问题马上就要北漂了,对未来是充满了期待也存在着恐惧,南方人头一次去这么远的地方,每天都能看到雪,可以跟实力强劲的同事合作,想想都很兴奋,但是也害怕自己不能胜任这份工作会被压力到爆,但是不管怎么样大家一起互勉吧,呆在舒适区只会停滞不前,压力才能带来成长
牛马人的牛马人生:勇敢追梦
2025年终总结
点赞 评论 收藏
分享
评论
1
3
分享

创作者周榜

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