杀人游戏(hdu2211)插入法
杀人游戏
Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 1375 Accepted Submission(s): 267
Problem Description
不知道你是否玩过杀人游戏,这里的杀人游戏可没有法官,警察之类的人,只有土匪,现在已知有N个土匪站在一排,每个土匪都有一个编号,从1到N,每次杀人时给定一个K值,从还活着的土匪中,编号从小到大的找到K个人,然后杀掉,继续往下,直到找遍,然后继续从剩下的土匪中,编号从小到大找到第K个活着的土匪,然后杀掉。比如,现在有10个土匪,K为3,第一次杀掉3,6,9号的土匪,第二次杀掉4,8号土匪,第三次杀掉5号土匪,第四次杀掉7号土匪,第五次杀掉10号土匪,我们看到10号土匪是最后一个被杀掉的(从1到K-1的土匪运气好,不会被杀!)。现在给定你一个N和一个K,问你最后一个被杀掉的土匪的编号是多少。
Input
第一行有一个T(T<=10000),接下来有T组数据,每组中包含一个N(N<2^31)和一个K(3<=K<=100&&K<N)。
Output
对于每组数据,输出最后被杀的土匪的编号。
Sample Input
1
10 3
Sample Output
10
拖了好久啊,,,,,,今天要谢谢老板哈!插数,,,原来如此!
这是一道很有趣的题目,
#include<stdio.h> int main() { __int64 t,n,k,count,luck,s,p,i; scanf("%I64d",&t); while(t--) { scanf("%I64d%I64d",&n,&k); p=k-1;//插入周期eg:k=3,那么p=2;两个一插 for(s=k;s<n;)//s为标记,来标记luckboy的位置 { i=(s-1)/p;//计算s前面插几个 luck=s;//luck是记录上一个s的值 s=s+i; } printf("%I64d\n",luck); } return 0; }
以题例为例,他的流程图如下,s代表luck boy的位置,数字带下划线表示刚插入的数
是不是 so easy 啊! 关键是方法!!!
1 2 s(3)
1 2 3 s(4)
1 2 3 4 s(5) 6
1 2 3 4 5 6 s(7) 8 9
1 2 3 4 5 6 7 8 9 s(10) 11 12 13
够短小吧,再者我之前的代码是:
#include<stdio.h> int main() { int t,k; __int64 i,j,n,count,p; __int64 a[100000],luck; scanf("%d",&t); while(t--) { scanf("%I64d%d",&n,&k); for(i=1;i<=n;i++) a[i]=i; count=0; for(i=k;i<=n;i++) { if(a[i]%k==0) {a[i]=0;count++;} } for(i=1,j=0;(n-count)>=k;i++) { if(a[i]!=0) j++; if(j==k) {luck=a[i];a[i]=0;count++;j=0;} if(i==n) {i=0;j=0;} } printf("%I64d\n",luck); } return 0; }
这就是差距,大神就是大神,学长牛牛,,,我也要加油
转载请注明出处:http://www.cnblogs.com/yuyixingkong/
自己命运的掌控着!