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;
}

 

全部评论

相关推荐

合适才能收到offe...:项目岗是什么岗?我看你有段好像跟策划运营相关,如果找运营的话第三段经历写详细点儿。 个人建议是把自我评价删了换成专业技能放在工作经验上或者下面。学生会那个也可以删,把第一个包装成店铺运营,写4-6给点。第三个也是写4-6个点。注意工作内容➕部分数据。 投递的时候BOS招呼用语改一下,换成我有xx工作经验,熟练掌握xx技能样式,也可以简历截图然后直接发送。
点赞 评论 收藏
分享
牛至超人:您好,京东物流岗了解一下吗?负责精加工食品的端到端传输
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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