当前位置:网站首页>【C语言】虐打循环练习题(2)
【C语言】虐打循环练习题(2)
2022-08-02 13:04:00 【凡人编程传】
作者:凡人编程传
系列:C语言初阶(适合小白入门)
说明:以凡人之笔墨,书写未来之大梦
前言
这一节我们接着练习循环练习题,话不多说,直接上题了。
第一题
题目:编写一个程序,演示多个字符从两端移动向中间汇聚。(动态)
题目分析:题目的意思是说这个程序是动态演示一个字符串的向中间显示的过程,所以这里我们要肯定用到数组的知识,即使一个数组存放要显示的字符串动态覆盖另一个数组的过程来达到动态汇聚的现象.那么既然是要从两边汇聚到这中间,这是不是要有两个变量来控制数组下标得覆盖啊,有点像我们上一节讲的二分查找的下标控制方法吧。好的说了这么多不如看一下图:
像上面几个箭头一样上面的一个数组的元素通过左右下标来控制从两边覆盖第二个数组,由此来达到两端移动向中间汇聚的动作(当然光这样直接显示肯定是没有动态的还需要使用一些库函数)
代码如下:
#include<stdio.h>
#include<string.h>
int main()
{
char arr1[] = "welcome to bit!!!!!!!!!";
char arr2[] = "#######################";
int left = 0; //左控制下标
int right = strlen(arr1) - 1; //右控制下标,这里的strlen是库函数,用于求字符串的长度,而数组下标从0开始,所以最后一个字符的下标还要减1
while (left <= right)
{
arr2[left] = arr1[left]; //左边覆盖
arr2[right] = arr1[right]; //右边覆盖
printf("%s\n", arr2);
left++;
right--;
}
return 0;
}
运行结果:
很多人认为到这就完了,注意题目的要求要显示向中间汇聚的动态过程,而这个是直接一些子就有了结果,所以我们不妨改进一下
#include<stdio.h>
#include<string.h>
#include<Windows.h>
int main()
{
char arr1[] = "welcome to bit!!!!!!!!!";
char arr2[] = "#######################";
int left = 0; //左控制下标
int right = strlen(arr1) - 1; //右控制下标,这里的strlen是库函数,用于求字符串的长度,而数组下标从0开始,所以最后一个字符的下标还要减1
while (left <= right)
{
arr2[left] = arr1[left]; //左边覆盖
arr2[right] = arr1[right]; //右边覆盖
printf("%s\n", arr2);
Sleep(1000); //睡眠函数,以毫秒为单位,让程序暂停运行1秒
system("cls"); //清屏系统函数,每次执行一次会清空屏幕.
left++;
right--;
}
printf("%s\n", arr2); //因为最后被清了屏幕的,所以还需要再循环外面打印一次结果
return 0;
}
运行结果:
录屏
第二题
题目:编写一个程序,模拟用户登录的场景,并且只能登陆三次(只能输入三次密码,若三次内成功,则提示登陆成功,超过三次则退出程序)
题目分析:这道题的关键是控制只能输入三次密码,这就要用到我们的循环吧。还有一个关键就是怎么把输入的密码和原先假设的密码进行比较是否一样,是直接用==比较吗?还是另有其他的呢
不说太多,这道题根据上述的分析已经能写出来大概。上代码:
#include<stdio.h>
#include<string.h>
int main()
{
char password[10] = {
0 }; //存放密码的数组
int i = 0;
for (i = 0; i < 3; i++)
{
printf("请输入密码:");
scanf("%s", password);
if (strcmp(password, "123456") == 0)
{
printf("登陆成功\n"); //密码正确就马上break跳出循环,防止密码正确了还要进入循环输入密码
break;
}
else
{
printf("密码错误\n");
}
}
if (i == 3)
{
printf("退出程序\n"); //此时密码已经超过3次(i是从0开始循环的)
}
return 0;
}
这里的strcmp()函数则是字符串比较函数,若第一个字符串和第二个字符串相等则函数返回0,若第一个字符串比第二个字符串大则返回一个大于0的数;若第一个字符串比第二个字符串才小则返回一个小于0的数;
运行结果:
注意:
这里我假设密码不是123456,而是hello bit(带有空格)请看结果
你会发现,明明按照输入的正确密码不仅不是正确密码下一次要输入时他却自动提示错误(就是代表已经输入了密码),我们不妨调试一下
注意看右边password的元素变化情况,第二次输入的hello bit只存放了hello进去,说明%s遇到空格会自动结束读取,我们在: 【C语言】手撕循环结构 —— while语句这篇文章的while语句的扩展使用中的一个例子中介绍过一个叫字符缓冲区的概念.而这次导致自动第三次读取自动给读取的也是字符缓冲区还剩下第二次输入的bit而导致直接错误.
这里可以吧scanf()函数换成gets函数就可以解决这个问题,因为gets函数不会因为空格而停止读取,字符缓冲区回也就不会留下东西.
如:
结言
好了这一节的内容就是这些,若有不懂请在评论区留言。希望你有收获,我们下节见!!
边栏推荐
- 【typescript】使用antd中RangePicker组件实现时间限制 当前时间的前一年(365天)
- 方正璞华“劳动人事法律自助咨询服务平台”在武汉武昌区投入使用!
- Cannot determine loading status from target frame detached when selenium chrome driver is running
- Article 48 - Analysis of timestamp2 parameters【2022-08-01】
- js stopwatch countdown plugin
- FreeRTOS--Priority Experiment
- Wireless vibrating wire acquisition instrument remote modification method
- ThinkPHP 5.1反序列化分析和poc
- Intouch System Platform IDE-1
- pytorch模型转tensorflow模型
猜你喜欢
随机推荐
pytorch模型转tensorflow模型
js九宫格样式抽奖插件
Introduction to Graph Neural Networks (GNN) "Recommended Collection"
FreeRTOS--栈实验
Intouch System Platform IDE-1
openGauss数据库基本操作(超详细)
FreeRTOS experiment -- delete task
不错的射击类js小游戏源码
js秒表倒计时插件
图论之Kruskal,最小生成树如何优雅解题?
企业用直播平台能实现什么
selenium chrome driver运行时的cannot determine loading status from target frame detached问题
为什么IDEA连接mysql Unable to resolve table 编译报错但是可以运行
How to turn off hardware acceleration [easy to understand]
Intouch Historian历史曲线配置导入导出
微信小程序getPhoneNumber接口code=40013
动态组件-component
【C语言】明解数组(1)
暑假集训-week2图论
qt 编译报错 No rule to make target