C语言-分支语句和循环语句-练习题
程序员文章站
2022-04-06 12:16:42
...
分支语句和循环语句-练习题
- 判断一个数是否为奇数
- 输出1-100之间的奇数
- 从小到大输出三个数
- 打印1-100之间所有3的倍数的数字
- 判断m\n的打印结果(switch)
- getchar()
- 输入密码确认
- 只打印字符0-9,否则跳走(while)
- 请问代码循环多少次(for)
- 计算 n的阶乘或计算 1!+2!+3!+……+10!
- 在一个有序数组中查找具体的某个数字n。
- 编写int binsearch(int x, int v[], int n);
- 编写代码,演示多个字符从两端移动,向中间汇聚。
- 编写代码实现,模拟用户登录情景,并且只能登录三次。(只允许输入三次密码,如果密码正确则提示登录成,如果三次均输入错误,则退出程序。
- 给定两个数求最大公约数
- 打印1000-2000之间的闰年
- 打印100-200之间的素数《素数求解的n种境界》
- 编写程序数1-100所有整数中出现多少个数字9
- 计算1/1-1/2+1/3-1/4……-1/100
- 求10个整数的最大值
- 乘法口诀表
- 猜数字游戏
判断一个数是否为奇数
int num;
printf("输入一个数:");
scanf("%d", &num);
if (0 == num % 2) // 判断这个数除以 2 的余数
printf("%d 是偶数。", num);
else
printf("%d 是奇数。", num);
输出1-100之间的奇数
int i = 1;
while (i <= 100)
{
if (num & 1) // 判断这个数最后一位是1这为奇数
printf("%d ", num);
i++;
}
从小到大输出三个数
#include <stdio.h>
int main()
{
int a = 0, b = 0, c = 0;
scanf("%d%d%d", &a, &b, &c);
//算法实现a>b >c
if (a < b)
{
int tmp = a;
a = b;
b = tmp;
}
if (a < c)
{
int tmp = a;
a = c;
c = tmp;
}
if (b < c)
{
int tmp = b;
b = c;
c = tmp;
}
printf("%d %d %d\n", a, b, c);
return 0;
}
打印1-100之间所有3的倍数的数字
#include <stdio.h>
int main()
{
int i = 0;
for (i = 1; i <= 100; i++)
{
if (i % 3 == 0)
{
printf("%d ", i);
}
}
return 0;
}
判断m\n的打印结果(switch)
int n = 1;
int m = 2;
switch (n)
{
case 1: //没有break,符合case 1 完成case 1 继续执行case 2……
m++; //m=3,n=1
case 2:
n++; //m=3,n=2
case 3:
switch (n)
{ //switch允许嵌套使用
case 1: //未执行
n++;
case 2: //符合,执行,break,继续执行case 4
m++;
n++; //m=4,n=3
break;
}
case 4:
m++; //m=5,n=3
break; //跳出 switch
default: //未执行
break;
}
printf("m = %d, n = %d\n", m, n); //m = 5, n = 3
getchar()
int ch = getchar(); //getchar 接收键盘一个字符
putchar(ch); //putchar 输出
printf("%c", ch);
//代码1
#include <stdio.h>
int main()
{
int ch = 0;
//ctrl+z获取一个EOF -end of file->-1
while ((ch = getchar()) != EOF) //直接输入EOF不会停止,读入一个字符在写一个字符,EOF是三个字符
putchar(ch);
return 0;
}
输入密码确认
#include <stdio.h>
int main()
{
int ret = 0;
char password[20] = {0};
printf("请输入密码:"); //输入缓冲区:123456\n
scanf("%s", password); //输入密码,存放在password数组中
//缓冲区还剩余一个\n,\n-->10
// printf("%d", '\n'); //10
getchar(); //读取\n
printf("请确认(Y/N)?");
ret = getchar(); //Y /N
if (ret == 'Y')
{
printf("确认成功\n");
}
else
{
printf("放弃确认\n");
}
return 0;
}
若不加中间的**getchar();**则
加了
但还存在问题
修改代码为:
#include <stdio.h>
int main()
{
int ret = 0;
int ch = 0;
char password[20] = {0};
printf("请输入密码:"); //输入缓冲区:123456\n
scanf("%s", password); //输入密码,存放在password数组中
//缓冲区还剩余一个\n,\n-->10
// printf("%d", '\n'); //10
// getchar(); //读取\n
while ((ch = getchar()) != '\n')
{
; //空语句
}
printf("请确认(Y/N)?");
ret = getchar(); //Y /N
if (ret == 'Y')
{
printf("确认成功\n");
}
else
{
printf("放弃确认\n");
}
printf("密码为:%s\n", password);
return 0;
}
只打印字符0-9,否则跳走(while)
//代码2
#include <stdio.h>
int main()
{
int ch = 0;
//ctrl+z获取一个EOF -end of file->-1
while ((ch = getchar()) != EOF)
{
if (ch < '0' || ch > '9') //只打印字符0-9,否则跳走
continue;
putchar(ch);
printf("\n");
}
return 0;
}
请问代码循环多少次(for)
//请问循环要循环多少次?
#include <stdio.h>
int main()
{
int i = 0;
int k = 0;
for (i = 0, k = 0; k = 0; i++, k++)
//k=0,把0赋值为k,这个表达式的结果为k的值,即为0,为假,所以循环0次
k++;
for (i = 0, k = 0; k = 1; i++, k++) //k=1,2……不等于0,为真,死循环
k++;
return 0;
}
计算 n的阶乘或计算 1!+2!+3!+……+10!
#include <stdio.h>
int main()
{
int ret = 1, ret2 = 0;
int n = 0;
printf("请输入n:\n");
scanf("%d", &n);
int i = 1;
for (i = 1; i <= n; i++)
{
ret = ret * i;
ret2 = ret2 + ret;
}
printf("%d!=%d\n", n, ret); //计算 n的阶乘。
printf("1!+2!+……+%d!=%d", n, ret2); //1!+2!+……+n!
return 0;
}
在一个有序数组中查找具体的某个数字n。
#include <stdio.h>
int main()
{
int v[] = {1, 3, 6, 7, 9, 10, 12, 13, 16, 19};
int k = 7;
int i = 0;
int sz = sizeof(v) / sizeof(int);
//折半查找log2n
int left = 0; //左下表
int right = sz - 1; //右下标
int mid = 0;
while (left <= right)
{
mid = (left + right) / 2;
if (v[mid] > k)
{
right = mid - 1;
}
else if (v[mid] < k)
{
left = mid + 1;
}
else
break;
}
if (left <= right)
printf("找到了,下标是%d\n", mid);
else
printf("找不到\n");
//时间复杂度为O(n)
// for (i = 0; i < sz; i++)
// {
// if (k == v[i])
// {
// printf("找到了,下标是%d\n", i);
// break;
// }
// }
// if (sz == i)
// {
// printf("未找到");
// }
return 0;
}
编写int binsearch(int x, int v[], int n);
功能:在v[0]<=v[1]<=v[2]<= ….<=v[n-1]的数组中查找x.
//如果实现一个二分查找函数:
int bin_search(int arr[], int left, int right, int key)
{
int mid = 0;
while (left <= right)
{
mid = (left + right) >> 1;
if (arr[mid] > key)
{
right = mid - 1;
}
else if (arr[mid] < key)
{
left = mid + 1;
}
else
return mid; //找到了,返回下标
}
return -1; //找不到
}
编写代码,演示多个字符从两端移动,向中间汇聚。
#include <string.h>
#include <windows.h>
#include <stdlib.h>
#include <stdio.h>
int main()
{
//welcome to China!!!!!!
//######################
//w####################!
//we##################!!
// ……
char arr1[] = "welcome to China!!!!!!"; //以\0未结束
char arr2[] = "######################";
int left = 0;
//int right = sizeof(arr1) / sizeof(arr1[0]) - 2;
int right = strlen(arr1)-1;
while (left<= right)
{
arr2[left] = arr1[left];
arr2[right] = arr1[right];
printf("%s\n", arr2);
//休息1秒
Sleep(1000);
system("cls");//执行系统命令的一个函数-cls-清空屏幕
left++;
right--;
}
printf("%s\n", arr2);
return 0;
}
编写代码实现,模拟用户登录情景,并且只能登录三次。(只允许输入三次密码,如果密码正确则提示登录成,如果三次均输入错误,则退出程序。
#include <string.h>
#include <stdio.h>
int main()
{
int i = 0;
char password[20] = {0};
for (i = 0; i < 3; i++)
{
printf("请输入密码:>");
scanf("%s", password);
// if (password == "123456")//== 不能用来比较两个字符串是否相等,应该使用一个库函数-strcmp
if (strcmp(password, "123456") == 0)
{
printf("登录成功\n");
break;
}
else
{
printf("密码错误\n");
}
}
if (i == 3)
printf("三次密码均错误,退出程序\n");
return 0;
}
给定两个数求最大公约数
#include <stdio.h>
int main()
{
int m = 0;
int n = 0;
int r = 0;
scanf("%d%d", &m, &n);
//辗转相除法
while (r = m % n) //余数 4%6=4 6%4=2
{
m = n;
n = r;
}
printf("%d\n", n);
return 0;
}
打印1000-2000之间的闰年
#include <stdio.h>
int main()
{
int i = 0;
int count = 0;
for (i = 1000; i <= 2000; i++)
{
//判断year 是否为闰年
// 1. 能被4整除,且不能被100整除的是闰年
// 2. 能被400整除是闰年
// if (i % 4 == 0 && i % 100 != 0)
// {
// count++;
// printf("%d ", i);
// }
// else if (i % 400 == 0)
// {
// count++;
// printf("%d ", i);
// }
if ((i % 4 == 0 && i % 100 != 0) || i % 400 == 0)
{
count++;
printf("%d ", i);
}
}
printf("\ncount=%d\n", count);
return 0;
}
打印100-200之间的素数《素数求解的n种境界》
#include <math.h>
#include <stdio.h>
int main()
{
int i = 0;
int count = 0;
//sqrt - 开平方的数学库函数
for (i = 101; i <= 200; i += 2) //排除所有偶数
{
//判断i是否为素数
//素数判断的规则
//1. 试除法: 产生2->i-1
// i=a*b a和b中至少有一个数字≤开平方i
int j = 0;
for (j = 2; j <= sqrt(i); j++) //i/2也是对的
{
if (i % j == 0)
{
break;
}
}
if (j > sqrt(i))
{
count++;
printf("%d ", i);
}
}
printf("\ncount=%d\n", count);
return 0;
}
编写程序数1-100所有整数中出现多少个数字9
#include <stdlib.h> //itoa所需要的库函数
#include <stdio.h>
int main()
{
int i = 0;
int j = 0;
int count = 1;
for (i = 1; i <= 100; i++)
{
// //法一:
// if (i % 10 == 9)
// {
// count++;
// }
// if (i / 10 == 9)
// {
// count++;
// }
//法二:使用itoa函数
char s[10] = {0};
itoa(i, s, 10); // itoa(int,char,要转换的进制数)
for (j = 0; j < strlen(s); j++)
{
if (s[j] == '9')
{
count++;
printf("%d ", i);
break;
}
}
}
printf("\ncount=%d\n", count);
return 0;
}
计算1/1-1/2+1/3-1/4……-1/100
#include <stdio.h>
int main()
{
int i = 0;
double re = 0;
// int flag = 1;
// for (i = 1; i <= 100; i++)
// {
// re = re + flag * (1.0 / i);
// flag = flag * (-1);
// }
for (i = 1; i <= 100; i += 2)
{
re = re + 1.0 / i;
}
for (i = 2; i <= 100; i += 2)
{
re = re - 1.0 / i;
}
printf("%lf", re);
return 0;
}
求10个整数的最大值
#include <stdio.h>
int main()
{
int arr[] = {1, 23, 4, 5, 6, 7, 32, 13, 33, 54};
int i = 0;
int max = arr[0]; //如果max=0,则无法判断负数
for (i = 1; i < sizeof(arr) / sizeof(arr[0]); i++)
{
if (arr[i] > max)
{
max = arr[i];
}
}
printf("max=%d\n", max);
return 0;
}
乘法口诀表
#include <stdio.h>
int main()
{
int i = 0, j = 0;
for (i = 1; i < 10; i++)
{
for (j = 1; j <= i; j++)
{
printf("%d * %d = %-2d ", j, i, i * j); //不够两位补空格
}
printf("\n");
}
return 0;
}
猜数字游戏
- 电脑会生成一个随机数
- 猜数字
注:
时间戳:当前计算机时间-计算机的起始时间(1970.1.1.0:0:0)=(xxxx)秒
rand() RAND_MAX-32767
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
void menu()
{
printf("**********************************\n");
printf("*********** 1.play **********\n");
printf("*********** 0.exit **********\n");
printf("**********************************\n");
}
//TDD-测试驱动开发。
//RAND_MAX--rand函数能返回随机数的最大值。
void game()
{
//生成随机数
int random_num = rand() % 100 + 1; //1-100之间的
int input = 0; //接收猜的数字
while (1)
{
printf("请输入猜的数字>:");
scanf("%d", &input);
if (input > random_num)
{
printf("猜大了\n");
}
else if (input < random_num)
{
printf("猜小了\n");
}
else
{
printf("恭喜你,猜对了\n");
break;
}
}
}
int main()
{
int input = 0;
srand((unsigned)time(NULL)); //拿时间戳设置一个随机起点,设置一次就可以,不要频繁调用
do
{
menu();
printf("请选择>:");
scanf("%d", &input);
switch (input)
{
case 1:
game();
break;
case 0:
printf("退出游戏!\n");
break;
default:
printf("选择错误,请重新输入!\n");
break;
}
} while (input);
return 0;
}
上一篇: 判断素数。——分支和循环练习
下一篇: Python - if 条件判断