C语言之基本算法05—韩信点兵

//枚举法
/*
==================================================================
题目:韩信带兵1500人,死四五百,站3人一排多2,5人一排多4,7人一排多
6,韩信一口说出士兵数量!
==================================================================
*/
#include<stdio.h>
main()
{
int n,r;
for(n=1000;n<1100;n++)             //共1500,死四五百,剩下人自然在这个范围。
if((n%3==2)&&(n%5==4)&&(n%7==6))   //站3人一排多2,5人一排多4,7人一排多6
printf("韩信说:有士兵%d人!",n);
printf("\n");
}
/*
==================================================================
题目:实质是枚举法!余数问题,定义士兵范围n(1000-1100),n%3=2,
n%5=4,n%7=6,求n。
==================================================================
*/
  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
韩信点兵C语言实现中使用了while循环来读取输入,并进行计算。具体实现如下: ```c #include <stdio.h> #include <stdlib.h> int main() { int a, b, c; int t = j; goto A; } } t[i = -1; A: i++; } for(k = 0; k < i; k++) { if(t[k != -1) { printf("Case %d: %d\n", k + 1, t[k]); } else { printf("Case %d: No answer\n", k + 1); } } return 0; } ``` 该程序从标准输入读取输入数据,然后通过循环遍历10到100的数,判断是否满足条件。如果找到满足条件的数,则将其存入数组t中,并通过标签A跳出内层循环。最后,程序通过循环打印出每组数据的结果。 另外,还有一种使用枚举的实现方法,具体代码如下: ```c #include <stdio.h> #include <stdlib.h> int main() { int a, b, c; int kase = 0; int flag = 1; while(scanf("%d", &a) == 1) { scanf("%d", &b); scanf("%d", &c); int i = 10; for(i; i < 100; i++) { if(i % 3 == a && i % 5 == b && i % 7 == c) { printf("Case %d: %d\n", kase, i); flag = 0; } } if(flag) printf("No answer.\n"); flag = 1; } return 0; } ``` 这种实现方法使用了枚举来遍历10到100的数,判断是否满足条件,并打印出结果。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [韩信点兵算法——c语言实现](https://blog.csdn.net/Rebaccaminmin/article/details/54925065)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [韩信点兵 C语言](https://blog.csdn.net/jpsodope/article/details/110037786)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值