栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

系统会给定一串数字让玩家选择,如果玩家选中一个数字,比如M,那么玩家获得M分,但同时当前选中的M,以及这串数字中所有的M+1和M

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

系统会给定一串数字让玩家选择,如果玩家选中一个数字,比如M,那么玩家获得M分,但同时当前选中的M,以及这串数字中所有的M+1和M

参考回答:

public class Select {public static void main(String[] args) {int[] a = {2,3,3,3,4};int max = 0;for(int i=0;i<a.length;i++) {if(max<a[i])max=a[i];}int[] num = new int[max+1];for(int i=0;i<a.length;i++) {num[a[i]]++;}System.out.println(maxSum(1,max,num));}public static int maxSum(int start, int end, int[] num){int[] sum = new int[end+1];sum[1] = num[1]*1;sum[2] = Max(num[1]*1,num[2]*2);sum[3] = Max((num[1]*1+num[3]*3),num[2]*2);for(int i=4;i<end+1;i++) {sum[i] = Max(num[i]*i+sum[i-2],num[i-1]*(i-1)+sum[i-3]);}return sum[end];}public static int Max(int m, int n){if(m>n)return m;else return n;}}

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/363863.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号