/**
韩信点兵
从1至5报数,最后一个士兵报数为1;
从1至6报数,最后一个士兵报数为5;
从1至7报数,最后一个士兵报数为4;
从1至11报数,最后一个士兵报数为10
*/
// 解法1,从1开始穷举,答案:士兵有2111人
- (void)hanXinDianBing {
NSInteger i = 0;
while (1) {
i+=1;
if ((i % 5 == 1) && (i % 6 == 5) && (i % 7 == 4) && (i % 11 == 10)) {
NSLog(@" 士兵有%ld人",(long)i);
break;
}
}
}
// 解法2,改进版
/**
1.x 除以11余10,于是可以设置x从21开始,以步长11递增.此时,只要判别前3个条件即可.
2.或者,由以上2和4条件得知,x+1为11的倍数,也为6的倍数,11与6互素,因此x+1必须为66的倍数.于是去x=65开始,步长66递增,此时,只要判别x%5=1,与x%7=4两个条件即可
*/
- (void)hanXinDianBingFunc2 {
NSInteger x = 65;
while (1) {
x += 66;
if ((x % 5 == 1) && (x % 7 == 4)) {
NSLog(@" 士兵有%ld人",(long)x);
break;
}
}
}
韩信点兵
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...