前言 这篇是对分支与循环语句等知识的练习以及补充,让我们一起练起来吧
1.计算n的阶乘
#includeint main()
{
int n = 0;
scanf("%d", &n);
int ret = 1;
int i = 0;
for (i = 1;
i <= n;
i++)
{
ret *= i;
}
printf("%d", ret);
return 0;
}
文章图片
2.计算1!+2!+3!+…+10!
#includeint main()
{
int n = 0;
scanf("%d", &n);
int i = 0;
int j = 0;
int ret = 1;
int sum = 0;
for (i = 1;
i <= n;
i++)
{
ret = 1;
for (j = 1;
j <= i;
j++)
{
ret *= j;
}
sum += ret;
}
printf("%d", sum);
return 0;
}
文章图片
大家看到上面的方法虽然可以达到要求,但是效率低下,我们可以优化一下代码:
#includeint main()
{
int n = 0;
scanf("%d", &n);
int i = 0;
int ret = 1;
int sum = 0;
for (i = 1;
i <= n;
i++)
{
ret *= i;
sum += ret;
}
printf("%d", sum);
return 0;
}
文章图片
像上面这样我们就可以在一层循环里面解决问题。
3.在一个有序数组中查找具体的某个数字n(二分查找安全版)
二分查找具体的思路和实现,咱们以前已经讨论过,大家想要看一下可以去看:c语言基础篇:二分查找
这里是对二分查找的一种安全方法的讲述
大家有没有想过如果left和right的值是一个很大很大的数,虽然它们两个没有超过整型的范围,但是它们两个加起来就会超过整型的范围,那么这个时候我们该如何改变就能使代码变得安全起来?像下面这样将(right - left)/ 2加在left上赋给mid这样mid就不会超过整型的范围对代码进行安全保护。
文章图片
代码如下:
#includeint main()
{
int arr[] = { 0,1,2,3,4,5,6,7,8,9 };
int left = 0;
int right = sizeof(arr) / sizeof(arr[0]);
//计算数组的长度
int n = 7;
int mid = 0;
while (left <= right)//如果left > right说明没有这个元素
{
mid = left + (right - left) / 2;
if (arr[mid] < n)
{
left = mid + 1;
}
else if (arr[mid] > n)
{
right = mid - 1;
}
else
{
printf("找到了,下标为%d\n", mid);
break;
}
if (left > right)
{
printf("找不到\n");
}
} return 0;
}
文章图片
4.编写代码,演示多个字符从两端移动,向中间汇聚
#include
#include
#include
#include//Hello World!
//############
//H##########!
//He########d!
//Hel######ld!
//.....
//Hello World!int main()
{
char arr1[] = "Hello World!";
char arr2[] = "############";
int left = 0;
int right = strlen(arr1) - 1;
while (left <= right)
{
arr2[left] = arr1[left];
arr2[right] = arr1[right];
printf("%s\n", arr2);
Sleep(1000);
//window下Sleep函数参数的单位使毫秒
system("cls");
left++;
right--;
}
printf("%s\n", arr2);
return 0;
}
文章图片
5.编写代码实现,模拟用户登录情景,并且只能登录三次。(只允许输入三次密码,如果密码正确则提示登录成,如果三次均输入错误,则退出程序。
//编写代码实现,模拟用户登录情景,并且只能登录三次。(只允许输入三次密码,如果密码正确则
//提示登录成,如果三次均输入错误,则退出程序。//假设正确的密码是:"bitbit"
//string compare - strcmp
#include
#include //C语言中有字符串吗? - 有 ""
//C语言中有字符串类型吗? 没有
//string - C++
//
//strcmp 的返回值
//>0
//<0
//==0
int main()
{
int i = 0;
char password[20] = { 0 };
for (i = 0;
i < 3;
i++)
{
printf("请输入密码:>");
scanf("%s", password);
//判断密码正确性
if (strcmp(password, "bitbit") == 0)
{
printf("密码正确,登陆成功\n");
break;
}
else
{
printf("密码错误\n");
}
}
if (i == 3)
{
printf("三次密码错误,退出程序\n");
}
return 0;
}
【【从0到1|c语言(查漏补缺(二))】
文章图片
推荐阅读
- 【从0到1|c语言基础篇(结构体(初阶))
- 【从0到1|初识c语言(一)
- 【从0到1|初识c语言(二)
- C语言|深度解析C语言之递归求解算法
- 基础知识|C语言递归
- 算法|二进制,八进制,十进制,十六进制的相互转换【简单易懂】
- c语言|在ARM64下编程的常见陷阱(C语言常见陷阱)
- 树莓派|树莓派镜像制作
- C语言|(师承郝斌老师)C语言——结构体