【鹏哥C语言网课笔记】分支和循环语句

2023-11-21 05:40

本文主要是介绍【鹏哥C语言网课笔记】分支和循环语句,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

P7-分支和循环(1)

1.else的匹配:

2.输出1-100之间的奇数

3.判断一个数是否为奇数

4.switch

5.练习

6.while语句中的break和continue

7.简单提及putchar与getchar

P8-分支和循环(2)

密码输出代码

只输出数字,不输出非数字代码:

1.for语句中的break和continue

2.for语句的循环控制变量

3.do while循环中的break和continue

4.代码练习

①计算n的阶乘

②计算1!+2!+3!+...+10!

③在一个有序数组中查找具体的某个数字n。

④编写代码,演示多个字符从两端移动,向中间汇聚

⑤编写代码实现,模拟用户登录情景,并且只能登录三次。

P9-分支和循环-作业+练习

选择题

写代码题

写代码将三个数按从大到小输出

写一个代码打印1-100之间所有3的倍数的数字

给定两个数,求这两个数的最大公约数(利用辗转相除法)

打印1000年到2000年之间的闰年

打印100-200之间的素数(试除法,开平方法,代码再优化)

编写程序数一下1-100的所有整数中出现多少个数字9

编写程序数一下1-100的所有整数中出现多少个数字带9

分数求和:计算1/1-1/2+1/3-1/4+1/5.....+1/99-1/100的值,打印出结果

求10个整数中最大值

在屏幕上输出9*9乘法口诀表

二分查找:编写代码在一个整型有序数组中查找具体的某个数

猜数字游戏

goto语句

关机程序


P7-分支和循环(1)

1.else的匹配

else是和它离的最近的if匹配的

2.输出1-100之间的奇数

#include<stdio.h>
int main(){//输出1-100全部奇数 int i;for(i=1;i<=100;i++){if(i%2==0){continue;	}else{printf("%d\t",i);}}return 0;
}

3.判断一个数是否为奇数

#include<stdio.h>	
//判断输入数是否是奇数 
int main(){int i;printf("请输入一个数,让我们来判断是否是奇数:");scanf("%d",&i);if(i%2==0){printf("%d这个数不是奇数",i);}else{printf("%d这个数是奇数",i);}return 0;
}

4.switch

switch(整型表达式)

  {
语句项;
   }

5.练习

6.while语句中的breakcontinue

break:使流程跳到循环体之外,接着执行循环体下面的语句
其实在循环中只要遇到break,就停止后期的所有的循环,直接终止循环。
所以:while中的break是用于永久终止循环的
//break 代码实例
#include <stdio.h>
int main()
{int i = 1;while(i<=10){if(i == 5)break;printf("%d ", i);i = i+1;}return 0; 
}输出:
1 2 3 4

continue:跳过本次循环后面的所有代码,执行下一次循环

continue是用于终止本次循环的,也就是本次循环中continue后边的代码不会再执行,而是直接跳转到while语句的判断部分。进行下一次循环的入口判断

//continue 代码实例1
#include <stdio.h>
int main()
{int i = 1;while(i<=10){if(i == 5)continue;printf("%d ", i);i = i+1;}return 0; 
}输出:
1 2 3 4
//continue 代码实例2
#include <stdio.h>
int main()
{int i = 1;while(i<=10){i = i+1;if(i == 5)continue;printf("%d ", i);}return 0; 
}输出:
2 3 4 6 7 8 9 10 11

7.简单提及putchar与getchar

P8-分支和循环(2)

密码输出代码

 

分析:

 

正确写法:

 

只输出数字,不输出非数字代码:

1.for语句中的breakcontinue

break:

#include<stdio.h>
int main(){	int i=0;for(i=1;i<=10;i++){if(i==5){break;}printf("%d",i);		 }return 0;
}输出:
1 2 3 4

 continue:

#include<stdio.h>
int main(){	int i=0;for(i=1;i<=10;i++){if(i==5){continue;}printf("%d",i);		 }return 0;
}输出:
1234678910

while和for中break和continue运行的差别:

我们发现在for循环中出现的breakcontinue,他们的意义和在while循环中是一样的。

但是还是有些差异:

2.for语句的循环控制变量

①不可在for 循环体内修改循环变量,防止 for 循环失去控制。
②建议for语句的循环控制变量的取值采用“前闭后开区间”写法。
int i = 0;
//前闭后开的写法
for(i=0; i<10; i++)
{
}
//两边都是闭区间
for(i=0; i<=9; i++)
{
}

③for循环的初始化、调整、判断都可以省略,但是:for循环的判断部分如果被省略,那判断条件就是:恒为正,可能会照成一直满足条件一直输出。如果对代码不是非常熟练,建议不要随便省略

使用多余一个变量控制循环int x, y;for (x = 0, y = 0; x<2 && y<5; ++x, y++){printf("hehe\n");}return 0; 
}输出:
hehe
hehe
//请问循环要循环多少次?
#include <stdio.h>
int main()
{int i = 0;int k = 0;for(i =0,k=0; k=0; i++,k++)k++;return 0;
}代码循环0次
因为条件判断部分k=0,0为假,循环不执行同理:如果k=1,条件一直为真,循环陷入死循环

3.do while循环中的breakcontinue

break:

#include <stdio.h>
int main()
{int i = 1;do{if(i == 5)break;printf("%d\n", i);i++;}while(i<=10);return 0; 
}输出:
1
2
3
4

continue:

#include <stdio.h>
int main(){int i = 1;do{if(i == 5)continue;printf("%d\n", i);i++; }while(i<=10);return 0; 
}输出:
1
2
3
4

4.代码练习

①计算n的阶乘

#include<stdio.h>
int main(){	
//计算n的阶乘int i;int num;int mul;printf("想求这个数的阶乘为多少:");scanf("%d",&num); for(i=1;i<=num;i++){mul*=i;} printf("%d这个数的阶乘为:%d",num,mul);return 0;
}

②计算1!+2!+3!+...+10!

#include<stdio.h>
int main(){	int i;int j;int mul=1;int sum;for(i=1;i<=10;i++){for(j=1;j<=i;j++){mul*=j;}sum+=mul;mul=1;} printf("1!+2!+3!+...+10!的值为:%d",sum);
}

在一个有序数组中查找具体的某个数字n。

编写int binsearch(int x,int v[],int n);功能:在v[0]<=v[1]<=v[2]<=...<=v[n-1]的数组中查找x

折半查找法/二分查找法

 

 折半查找---csdn

④编写代码,演示多个字符从两端移动,向中间汇聚

代码1:
#define _CRT_SECURE_NO_WARNINGS 1#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;while(left<=right){arr2[left] = arr1[left];arr2[right] = arr1[right];printf("%s\n",arr2);Sleep(1000);left++;right--;//printf("%s\n", arr2);}return 0;
} 

代码2:对代码1进行了进一步更近
#define _CRT_SECURE_NO_WARNINGS 1#include<stdio.h>
#include<string.h>
#include<windows.h>
#include<stdlib.h> //为了使用system("cls");int main(){char arr1[] = "welcome to bit...";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); //休息一秒 system("cls"); //执行系统命令的一个函数-cls-清空屏幕 left++;right--;}printf("%s\n",arr2); return 0;
} 

 

 

编写代码实现,模拟用户登录情景,并且只能登录三次。

(只允许输入三次密码,如果密码正确则提示登录成,如果三次均输入错误,则退出程序)

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>
#include<windows.h>
#include<stdlib.h> int main(){int i=0;char password[20]={0};for(i=0;i<3;i++){printf("请输入密码:>");scanf("%s",password);//	if(password=="123456"){  ==不能用来比较两个字符串是否相等,应该使用一个库函数-strcmpif(strcmp(password,"123456")==0){ printf("登录成功\n");break;}else{printf("密码错误\n");}}if(i==3){printf("三次密码均错误,退出程序\n");}return 0;
}

P9-分支和循环-作业+练习

选择题

 

 

 

 

 

 

 

 

 

 

 

写代码题

写代码将三个数按从大到小输出

#include<stdio.h>
int main()
{int a = 0;int b = 0;int c = 0;scanf("%d%d%d",&a,&b,&c);//scanf里"%d%d%d"以什么形式,运行的时候就要输入什么形式//比如%d,%d,%d  运行时输入数字应该为 2,3,1//比如%d#%d#%d  运行时输入数字应该为 2#3#1//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;
}

给定两个数,求这两个数的最大公约数(利用辗转相除法)

#include<stdio.h>
int main()
{int m,n,r;scanf("%d %d",&m,&n);while(m%n){r = m%n;m = n;n = r;}printf("%d\n",n);return 0;
}#include<stdio.h>
int main()
{int m,n,r;scanf("%d %d",&m,&n);while(r=m%n){m = n;n = r;}printf("%d\n",n);return 0;
}

打印1000年到2000年之间的闰年

//判断是否是闰年:
//1.能被4整除并且不能被100整除是闰年
//2.能被400整除是闰年 
#include<stdio.h>
int main()
{	int year = 0;int count = 0;for(year=1000;year<=2000;year++){if(year%4==0 && year%100!=0){printf("%d ",year);count++;}else if(year%400==0){printf("%d ",year);count++;}} printf("\ncount=%d\n",count);return 0;
}
#include<stdio.h>
int main()
{int year = 0;int count = 0;for(year=1000;year<=2000;year++){if(((year%4==0)&&(year%100!=0))||(year%400==0)){printf("%d ",year);count++;}
}printf("\ncount = %d\n",count);return 0;
}

打印100-200之间的素数(试除法,开平方法,代码再优化)

//试除法
//素数又称质数。所谓素数是指除了1和它本身以外,不能被任何整数整除的数
//例如17就是素数,因为它不能被 2~16 的任一整数整除。
#include<stdio.h>
int main()
{int i = 0;int count = 0;for(i=100;i<=200;i++){int j = 0;for(j=2;j<i;j++) //看j<i的范围是否2->i-1之间有整数能把这个数整除 {if(i%j==0)  //如果能整除,就结束循环,说明该数并不是素数 {break;}}if(j==i)  //如果上面循环走完并没有被整除,就看j==i这个剩余的范围,符合就说明是素数 {printf("%d ",i);count++;}}printf("\ncount=%d\n",count);return 0;
} 
//开平方法
//若i=a*b
//a和b中至少有一个数字 <= 开平方i
//如16=2x8=4x4  其中2<4
//sqrt-开平方的数学库函数 
#include<stdio.h>
#include<math.h> 
int main()
{int i = 0;int count = 0;for(i=100;i<=200;i++){int j = 0;for(j=2;j<=sqrt(i);j++)  {if(i%j==0)  {break;}}if(j>sqrt(i))  {printf("%d ",i);count++;}}printf("\ncount=%d\n",count);return 0;} 
//对代码再进行优化
#include<stdio.h>
#include<math.h> 
int main()
{int i = 0;int count = 0;for(i=101;i<=200;i+=2)    //因为偶数一定不是素数{int j = 0;for(j=2;j<=sqrt(i);j++)   {if(i%j==0)  {break;}}if(j>sqrt(i))  {printf("%d ",i);count++;}}printf("\ncount=%d\n",count);return 0;} 

编写程序数一下1-100的所有整数中出现多少个数字9

#include<stdio.h>
int main()
{int i = 0;int count = 0;for(i=1;i<=100;i++){if(i/10==9){printf("%d ",i);count++;}if(i%10==9){printf("%d ",i);count++;}}printf("\ncount=%d",count);return 0;} 

编写程序数一下1-100的所有整数中出现多少个数字带9

#include<stdio.h>
int main()
{int i = 0;int count = 0;for(i=1;i<=100;i++){if(i/10==9){printf("%d ",i);count++;}else if(i%10==9){printf("%d ",i);count++;}}printf("\ncount=%d",count);return 0;} 

分数求和:计算1/1-1/2+1/3-1/4+1/5.....+1/99-1/100的值,打印出结果

①看奇偶位
#include<stdio.h>
int main()
{int i = 0;int count = 0;double sum = 0.0;for(i=1;i<=100;i++){count++;if(count%2==0){sum-=1.0/i;}else{sum+=1.0/i;}}printf("%lf ",sum);return 0;
}
②直接对正负号进行轮流变化
#include<stdio.h>
int main()
{int i = 0;double sum = 0.0;int flag = 1;for(i=1;i<=100;i++){sum += flag*1.0/i;flag = -flag;}printf("%lf ",sum);return 0;
}

求10个整数中最大值

①
#include<stdio.h>
int main()
{int arr[] = {-1,-2,-3,-4,-5,-6,-7,-8,-9,-10};int max = arr[0];  //让第一个元素为max,让后面的数与它进行对比int i = 0;int sz = sizeof(arr)/sizeof(arr[0]);for(i=1;i<sz;i++){if(arr[i]>max){max = arr[i];}}printf("max = %d\n",max);return 0;
}

在屏幕上输出9*9乘法口诀表

#include<stdio.h>
int main()
{int i = 0;int j = 0;int mul = 0;for(i=1;i<10;i++){for(j=1;j<=i;j++){mul=i*j;printf("%d*%d=%d\t",i,j,mul);}printf("\n");}return 0;
}

二分查找:编写代码在一个整型有序数组中查找具体的某个数

要求:找到了就打印数字所在的下标,找不到则输出:找不到

参考上节课代码练习③

猜数字游戏

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
void menu()
{printf("**********************************\n");printf("*********** 1.play     **********\n");printf("*********** 0.exit     **********\n");printf("**********************************\n");
}
//RAND_MAX-0-32767--rand函数能返回随机数的最大值。
void game()
{                                //实现1-100之间的随机数的生成int random_num = rand()%100+1;  //rand()是随机数生成函数需要搭配 srand((unsigned)time(NULL))使用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();  //选择玩游戏则调用game()函数进行游戏功能的实现break;case 0:break;default:printf("选择错误,请重新输入!\n");break;}
}while(input);return 0; 
}//注意:在game()中如果把随机数语句段放在while循环中,就会导致在游戏过程中,每猜一次随机数变化一次,导致如果第一次猜不对,就一直猜不对 
//rand()会回传一个乱数,rand()%100乱数会介于0~99之间,再+1会变成1~100之间,所以rand()%100+1就是一个1~100之间的乱数

goto语句

C 语言中提供了可以随意滥用的 goto 语句和标记跳转的标号。从理论上 goto 语句是没有必要的,实践中没有 goto 语句也可以很容易的写出代码。但是某些场合下goto 语句还是用得着的,最常见的用法就是终止程序在某些深度嵌套的结构的处理过程。
例如:一次跳出两层或多层循环。多层循环这种情况使用break 是达不到目的的。它只能从最内层循环退出到上一层的循环。
for(...)for(...){for(...){if(disaster)goto error;}}…
error:if(disaster)// 处理错误情况

关机程序

①
#include <stdio.h>
#include <cstdlib> 
#include <string.h>
int main()
{char input[10] = {0};system("shutdown -s -t 60");
again:printf("电脑将在1分钟内关机,如果输入:我是猪,就取消关机!\n请输入:>");scanf("%s", input);if(0 == strcmp(input, "我是猪")){system("shutdown -a");}else{goto again;}return 0; 
}
②
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{char input[10] = {0};system("shutdown -s -t 60");while(1){printf("电脑将在1分钟内关机,如果输入:我是猪,就取消关机!\n请输入:>");scanf("%s", input);if(0 == strcmp(input, "我是猪")){system("shutdown -a");break;}}return 0; 
}

这篇关于【鹏哥C语言网课笔记】分支和循环语句的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/400201

相关文章

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

poj3750约瑟夫环,循环队列

Description 有N个小孩围成一圈,给他们从1开始依次编号,现指定从第W个开始报数,报到第S个时,该小孩出列,然后从下一个小孩开始报数,仍是报到S个出列,如此重复下去,直到所有的小孩都出列(总人数不足S个时将循环报数),求小孩出列的顺序。 Input 第一行输入小孩的人数N(N<=64) 接下来每行输入一个小孩的名字(人名不超过15个字符) 最后一行输入W,S (W < N),用

论文阅读笔记: Segment Anything

文章目录 Segment Anything摘要引言任务模型数据引擎数据集负责任的人工智能 Segment Anything Model图像编码器提示编码器mask解码器解决歧义损失和训练 Segment Anything 论文地址: https://arxiv.org/abs/2304.02643 代码地址:https://github.com/facebookresear

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

数学建模笔记—— 非线性规划

数学建模笔记—— 非线性规划 非线性规划1. 模型原理1.1 非线性规划的标准型1.2 非线性规划求解的Matlab函数 2. 典型例题3. matlab代码求解3.1 例1 一个简单示例3.2 例2 选址问题1. 第一问 线性规划2. 第二问 非线性规划 非线性规划 非线性规划是一种求解目标函数或约束条件中有一个或几个非线性函数的最优化问题的方法。运筹学的一个重要分支。2

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX