学习完分支与循环语句后是不是觉得自己内心一阵空虚?
是不是觉的自己已经学废了?
别慌!悠漓这里还有巩固的习题,助力各位不再空虚!
计算n的阶乘。
int main()
{
int n = 0;
scanf("%d", &n);
//产生1~n的数字
int i = 0;
int ret = 1;
for(i = 1;i <= n;i++)
{
ret = ret * i;
}
printf("%dn", ret);
return 0;
}
计算 1!+2!+3!+……+10!
int main()
{
int n = 10;
scanf("%d", &n);
int i = 0;
int ret = 1;
int sum = 0;
for (i = 1; i <= n; i++)
{
ret = ret * i;
sum += ret;
//或者sum = ret + sum;
}
printf("%dn", sum);
return 0;
}
在一个有序数组中查找具体的某个数字n。
int main()
{
int arr1[] = { 1,2,3,4,5,6,7,8,9,10 };
int n = 0;
scanf("%d", &n);//查找n的下标
int sz = sizeof(arr1) / sizeof(arr1[0]);
int left = 0;//左下标
int right = sz - 1;//右下表
while (left <= right)
{
int mid = (right - left) / 2 + left;//中间元素下标
if (arr1[mid] < n)
{
left = mid + 1;
}
else if (arr1[mid] > n)
{
right = mid - 1;
}
else
{
printf("找到了,下标是:%d", mid);
break;
}
if (left > right)
{
printf("找不到了n");
}
}
return 0;
}
编写代码,演示多个字符从两端移动,向中间汇聚。
#include#include #include int main() { char arr1[] = "welcome to CSDN!!!!"; 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("%sn", arr2); Sleep(1000);//停留一秒后继续显示,需要引出头文件#include system("cls");//使用完以后清理屏幕,需要引出头文件#include left++; right--; } printf("%sn", arr2); return 0; }
编写代码实现,模拟用户登录情景,并且只能登录三次。(只允许输入三次密码,如果密码正确则
提示登录成,如果三次均输入错误,则退出程序。
#includeint main() { int i = 0; char password[20] = { 0 }; //假设正确的密码是"abcdef" for (i = 0; i < 3; i++) { printf("请输入密码:>"); scanf("%s", password);//没有取地址,因为数组名本身就是地址 //if(password == "abcdef")两个字符串的比较是不能使用"=="的 //应该使用strcmp if (strcmp(password, "abcdef") == 0) { printf("密码正确n"); break; } else { printf("密码错误,请重新输入:n"); } } if (i == 3) { printf("三次密码均输入错误,退出程序n"); } return 0; }



