//题目43:有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出 //圈子,问最后留下的是原来第几号的那位。 #include<stdio.h> #include<stdlib.h> //分析:用while循环实现 //定于数组的大小 #define N 6 void main(){ int a[N] = { 1, 2, 3 ,4,5,6}; //定义报数变量 int k = 1; //定义数组下标变量 int index = 0; //定义数组有用元素变量 int num = N; while (num != 1){ //确保元素下标不会越界 if (index>N - 1) { index = 0; } //当遇到已经删除的元素,要跳到下一个元素上 if (a[index] != 0) { if (k == 3) { //删除已经报3的元素 a[index] = 0; //实际元素个数减1 num--; //遇到3后 重置报数 k = 1; } else{ k++; } index++; } else{ index++; } } for (int i = 0; i < N; i++) { if (a[i]!=0) { printf("最后留下的是第%d号",a[i]); } } system("pause"); }
//题目44:写一个函数,求一个字符串的长度,在main函数中输入字符串,并输出其长度。 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<stdlib.h> //分析:自已一个字符串数组 void main(){ char str[50] = { 0 }; printf("请输入一个字符串 "); scanf("%s",str); int num = 0; while (str[num]!='