问个算法问题,康康大家有没有什么好的想法。。。

问个算法问题,康康大家有没有什么好的想法。。。

给一个N个数的混乱序列,序列中最多有N种数字(1 2 3 4 …… N),按顺序分成M组,即每一组数字在序列中必须是连续。

定义一组中不同数字的个数为这一组的值,求M组值的和的最大值。
#笔试题目#
全部评论
诶,这有点像昨天拼多多的题诶!
点赞 回复 分享
发布于 2019-10-18 11:19
回溯(m-1个分割点)+M个计数数组count(int[][] count = new int[m][n+1]),一个differentNumberCount数组,记录每个段里不同数字的个数(在第一次回溯之前便可得到每个段的不同数字个数,后续回溯如果是该段i增加了数字j,则count[i][j]是否等于0,等于0则differentNumberCount[i]+1,否则不变;如果该段i减少了数字j,则先判断count[i][j]是否等于1,如果是则differentNumberCount[i]-1,否则不变。当然,某个段增加或减少数字,对应段的该数字的计数也需要+1或-1)
点赞 回复 分享
发布于 2019-10-18 10:34

相关推荐

点赞 评论 收藏
分享
牛客583549203号:腾讯还好,况且实习而已,实习生流动性很大,属于正常现象,记得和HR委婉解释
点赞 评论 收藏
分享
Southyeung:我说一下我的看法(有冒犯实属抱歉):(1)简历不太美观,给我一种看都不想看的感觉,感觉字体还是排版问题;(2)numpy就一个基础包,机器学习算法是什么鬼?我感觉你把svm那些写上去都要好一点。(2)课程不要写,没人看,换成获奖经历;(3)项目太少了,至少2-3个,是在不行把网上学习的也写上去。
点赞 评论 收藏
分享
评论
1
1
分享

创作者周榜

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