从一道阿里的笔试题了解动态规划
程序IT圈
共 1178字,需浏览 3分钟
· 2020-04-15
动物之王
选动物老大,n个小动物,编号1-n,代表武力值,值越小,武力值越高,每个小动物都有一票投票权,可以投给自己或者自己崇拜的动物,或者和自己崇拜的动物跟票。
只能崇拜武力值比自己厉害的动物。
输入:第一行:n个动物 4
后面n行:
第几个小动物的崇拜对象 0 1 1 1
输出:每个小动物的最多的投票 4 1 1 1
解释:当第一个动物投自己 其余动物都投自己的崇拜的1号 那一号最多可以拿四票 然后其他动物如果都投自己 那么其余动物最多可以拿一票
思路这道题更多的考察的是一个动态规划的问题
每一个小动物都有三种选择
- 一种是选择投票给自己
- 一种是投票给自己崇拜的人
- 一种是和自己崇拜的人一样投相同的票
我们可以先构建一个数组来说明一下这三种情况发生的时候的场景
构建h数组 索引1-n代表着1号动物到n号动物所得到最大票数
构建arr数组 索引1-n 代表着1号动物到n号动物所崇拜的人是谁
0 代表着谁都不崇拜
举例当前动物的编号是n 崇拜的人是n-3
而n-3编号的动物崇拜的人是n-6
1.投票给自己 h[n]++
2.投票给崇拜的人 h[arr[n]]++ (此时arr[n]=n-3)
3.和自己崇拜的人投一样的票
h[h[arr[n]]]++(此时arr[n]=n-3 h[arr[n]]=h[n-3]=n-6)
我们针对所有的可能性 罗列了数组以及其赋值情况
当然遍历的顺序也是很重要的
题目中有一句话是这样的
每个动物只能崇拜武力值比自己厉害的动物
所以假设当前编号为n 那么只能崇拜 0 或者1-(n-1)的动物了
所以遍历顺序为从前往后遍历就行了
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.*;
public class Ali1 {
public static void main(String[] args) throws IOException {
BufferedReader r=new BufferedReader(new InputStreamReader(System.in));
String line[]=r.readLine().split(" ");
int n=Integer.valueOf(line[0]);//总共有几个动物
String line1[]=r.readLine().split(" ");
int[] arr=new int[n+1];
for (int i = 1; i <=n ; i++) {
arr[i]=Integer.valueOf(line1[i-1]);
} //索引变成了1-n 代表每个动物崇拜的人
int[] f=new int[n+1];//开辟一个数组存放投票的最大值
f[1]=1;//从1号开始 一号只能选0 所以先赋值为1
for (int i = 2; i <=n ; i++) {//从2号开始遍历
f[i]+=1;//第一种情况 是0
if(arr[i]==0){
continue;
}
else{
for (int j = arr[i]; j !=0 ; j=arr[j]) {
f[j]+=1;//第二或者第三种情况 投给崇拜的人 或者跟着崇拜的人跟票
}
}
}
for (int i = 1; i <=n ; i++) {
System.out.print(f[i]+" ");
}
}
}
程序IT圈-技术交流群已成立
扫码可添加小猿助手,可申请加入IT圈交流群,一定要备注:开发方向+地点+学校/公司+昵称,根据格式备注,可更快被通过且邀请进群
▲长按加群
更多技术好文,推荐关注
评论
真高!比亚迪员工爆料比亚迪在越南的薪资水平:基本工资480万,全勤奖35万,交通补助20万,餐补110万,每周6天,每天10小时
上一篇:某大公司为逼迫员工离职,竟然把他的工位安排到厕所旁,没想到他直接开始记录领导的如厕时间,还发到公司大群...对此,你怎么看?--完--PS:欢迎在留言区留下你的观点,一起讨论提高。如果今天的文章让你有新的启发,欢迎转发分享给更多人。全文完,感谢你的耐心阅读。如果你还想看到我的文章,请一定给本
开发者全社区
0
太敢穿了!透视纱裙!性感火辣的身材
绝了呀今天的厂花:吴宣仪1995年1月26日,吴宣仪出生于海南省海口市,中国内地流行乐女歌手、影视演员。2016年2月,吴宣仪随宇宙少女发行首张迷你专辑正式出道。2018年4月,她参加《创造101》综艺选秀,获得第二名,成功加入火箭少女101组合。吴宣仪的颜值一直备受称赞,她的五官立体精致,皮肤白皙
逆锋起笔
0
某大公司为逼迫员工离职,竟然把他的工位安排到厕所旁,没想到他直接开始记录领导的如厕时间,还发到公司大群...
上一篇:字节的跳动职级与薪资(2024年)我们与公司间的合作,宛如两艘船只在茫茫大海上相互依靠,共同抵御风浪,携手驶向成功的彼岸。然而,当航向开始产生分歧,或是波涛汹涌的风浪改变了我们的初衷,我们或许应当冷静地选择和平分手,而非在风雨中硬撑。最近,一位网友的遭遇引起了广大职场人的关注和热议。这位网友
开发者全社区
0
金融研究 | 使用Python测量关键审计事项的「信息含量」
Tips: 公众号推送后内容只能更改一次,且只能改20字符。如果内容出问题,或者想更新内容, 只能重复推送。为了更好的阅读体验,建议阅读本文博客版, 链接地址https://textdata.cn/blog/2023-01-13-information-content-of-critical-aud
大邓和他的Python
0
我看阿里的年终奖总算发了!
到4月底了,这两天看朋友圈,发现阿里的年终奖终于发了,问了问老同学,也从网上检索了不少信息,基本搞清楚了阿里今年的年终奖情况。近来来阿里一些集团对绩效等级做了较大的调整,以前的旧绩效系统中,绩效分为3.25、3.5、3.75、4和5五个等级,其中4和5是较高绩效等级,较少见。而且之前3.5绩效内部划
公子龙
0
CVPR 2024|大视觉模型的开山之作!无需任何语言数据即可打造大视觉模型
↑ 点击蓝字 关注极市平台作者丨科技猛兽编辑丨极市平台极市导读 本文提出一种序列建模 (sequential modeling) 的方法,不使用任何语言数据,训练大视觉模型。>>加入极市CV技术交流群,走在计算机视觉的最前沿本文目录1 序列建模打造大视觉模型(来自 U
极市平台
1
金融研究(更新) | 使用Python构建关键审计事项的「信息含量」
Tips: 公众号推送后内容只能更改一次,且只能改20字符。如果内容出问题,或者想更新内容, 只能重复推送。为了更好的阅读体验,建议阅读本文博客版, 链接地址https://textdata.cn/blog/2023-01-13-information-content-of-critical-aud
大邓和他的Python
0
字节的跳动职级与薪资(2024年)
上一篇:阿里公布年终奖,P7, 3.5+,22W年终奖,还有35W长期现金激励,真香字节跳动自2012年3月成立以来,已经迅速成长为一个全球性的科技公司。其产品和服务已经遍布全球150多个国家与地区,并且支持超过75种不同的语言。在字节跳动的官方网站上,列出了一系列引人注目的产品和服务,包括但不限于
开发者全社区
0