阿里后端开发岗java 0424第一题题解 dp动归

package com.Alibaba.exam0424;

public class Main3 {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		int n=6;
        int m=11;
        int[] arr= {4,12,3,7,6,2};    
        int[][] dp=new int[n][m];//m表示m种评价标准,0到m-1
        int tmp=arr[0]%m;
        for(int k=tmp;k<m;k++) {
        	dp[0][k]=tmp;//初始化
        }

        for(int i=1;i<n;i++) {
        	for(int j=0;j<m;j++) { 
        		int col=(j-arr[i])%m;
        		while(col<0) {
        			col+=m;
        			//col%=m;
        		}
        		int tmp2=Math.max(dp[i-1][j], (dp[i-1][col]+arr[i])%m);
                        dp[i][j]=Math.max(dp[i][j], tmp2);
        	}       	
        }
        System.out.println(dp[n-1][m-1]);
	}

}

                                

#阿里巴巴2020春招2021实习招聘##阿里巴巴##笔试题目##面经##实习#
全部评论
emmm贴主这个答案错的吧,输入用例[4.5.7.8.9] 应当输出 10 因为 5 + 7 + 9 = 21 % 11 = 10,而答主的程序输出结果是9😂这题困扰我半天了
点赞 回复 分享
发布于 2020-04-27 06:41
https://zhuanlan.zhihu.com/p/136158640 m是10^9 ,dp中存在m 肯定会超时
点赞 回复 分享
发布于 2020-04-25 12:40
你好,能描述一下题目吗?
点赞 回复 分享
发布于 2020-04-24 14:39

相关推荐

07-14 12:22
门头沟学院 Java
点赞 评论 收藏
分享
门口唉提是地铁杀:之前b站被一个游戏demo深深的吸引了。看up主页发现是个初创公司,而且还在招人,也是一天60。二面的时候要我做一个登录验证和传输文件两个微服务,做完要我推到github仓库,还要我加上jaeger和一堆运维工具做性能测试并且面试的时候投屏演示。我傻乎乎的做完以后人家跟我说一句现在暂时不招人,1分钱没拿到全是白干
你的秋招第一场笔试是哪家
点赞 评论 收藏
分享
Yki_:你要算时间成本呀,研究生两三年,博士三四年,加起来就五六年了,如果你本科去腾讯干五年,多领五年的年薪,加上公司内涨薪,可能到时候十五年总薪资也跟博士差不多
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
1
1
分享

创作者周榜

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