解决C语言中printf和scanf的执行顺序问题

#include <stdio.h>

int main()
{
   
	char a,b;   
   printf("石头剪刀布 \n");
   printf("规则\n");
	
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
要使用顺序表来解决约瑟夫环问题,可以按照以下步骤进行: 1. 首先,创建一个顺序表,用于表示约瑟夫环。顺序表可以使用数组来实现。 2. 初始化顺序表,将所有位置都设为0。0表示该位置上的元素已经被移除。 3. 设置一个变量,用于记录当前的位置。初始时,位置为0。 4. 设置一个变量,用于记录当前剩余的人数。 5. 进入循环,直到只剩下最后一个人。 a. 遍历顺序表,跳过已被移除的位置,找到下一个位置。 b. 判断是否已经遍历到最后一个位置。如果是,则将位置重置为0,并继续查找下一个位置。 c. 如果找到了下一个未被移除的位置,将当前位置标记为已移除,并将剩余人数减一。 d. 如果只剩下最后一个人,循环结束。 6. 循环结束后,剩下的最后一个人即为约瑟夫环的胜利者。 下面是一个使用顺序解决约瑟夫环问题的示例代码: ```c #include <stdio.h> #define MAX_SIZE 100 int josephus(int n, int m) { int seqList[MAX_SIZE] = { 0 }; int pos = 0; int remain = n; while (remain > 1) { int count = 0; while (count < m) { pos = (pos + 1) % n; if (seqList[pos] == 0) { count++; } } seqList[pos] = 1; remain--; } for (int i = 0; i < n; i++) { if (seqList[i] == 0) { return i + 1; } } return -1; } int main() { int n, m; printf("请输入总人数n和报数间隔m:"); scanf("%d%d", &n, &m); int winner = josephus(n, m); printf("胜利者的位置是:%d\n", winner); return 0; } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值