java杀人游戏_杀人游戏(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

Output

对于每组数据,输出最后被杀的土匪的编号。

Sample Input

1

10 3

Sample Output

10

拖了好久啊,,,,,,今天要谢谢老板哈!插数,,,原来如此!

这是一道很有趣的题目,

#include

intmain()

{

__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

{

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

intmain()

{intt,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;

}

这就是差距,大神就是大神,学长牛牛,,,我也要加油

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值