CodeForces - 892B (第一篇题解)写得不是很好


 

题意:有n个人,每个人都有长度不一样的爪子,所有人同时杀人,且只能杀在你前面的人(也就是数组小标比你小的人)

爪子长度的大小决定你可以杀在你前面的人数,问最后还剩多少人?

思路:这道题可以从最后面开始进行遍历,每次声明一个变量len把当前爪子当前所能够到的最前面的位置存进去,与前一个所能够到的位置(j - a[j])进行比较最小值,变量len就更新,循环不断判断当前位置是否大于len,循环一次就相当于杀一个人,最后再吧总人数减去杀掉的人数,就可以得到活下来的人数。

AC代码:

#include<stdio.h>
#define min(a, b) a<b?a:b
int a[1000005];
int main() {
	int n;
	scanf("%d", &n);
	for(int i = 0; i < n; i++) {
		scanf("%d", &a[i]);
	}
	int tot = 0;
//一次遍历就够了 如果一直比较下去 当len=0或者i=0时候循环就结束 
	for(int i = n - 1; i >= 0; i--) {
		int len = i - a[i];
		for(int j = i - 1; j >= len && j >= 0; j--) {
			len = min(j - a[j], len);
			i = len;
			tot++;
		}
	}
	printf("%d\n", n - tot);
	return 0;
}

 

全部评论

相关推荐

Yushuu:你的确很厉害,但是有一个小问题:谁问你了?我的意思是,谁在意?我告诉你,根本没人问你,在我们之中0人问了你,我把所有问你的人都请来 party 了,到场人数是0个人,誰问你了?WHO ASKED?谁问汝矣?誰があなたに聞きましたか?누가 물어봤어?我爬上了珠穆朗玛峰也没找到谁问你了,我刚刚潜入了世界上最大的射电望远镜也没开到那个问你的人的盒,在找到谁问你之前我连癌症的解药都发明了出来,我开了最大距离渲染也没找到谁问你了我活在这个被辐射蹂躏了多年的破碎世界的坟墓里目睹全球核战争把人类文明毁灭也没见到谁问你了😆
点赞 评论 收藏
分享
hso_:哈哈哈哈哈哈我没offer一样在同一道题开喷了
投递深圳同为数码等公司10个岗位
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务