29 分支语句ifelse
C语言是一门结构化的程序设计语言
1.顺序结构
2.选择结构
3.循环结构
分支语句
- if
- switch
循环语句
- while
- for
- do while
goto语句
语句:由一个分号;隔开的是一条语句
如果条件成立,要执行多条语句,应该使用代码块。
else和离它最近的未匹配的if语句匹配
if(5==num)//涉及到一个常量和一个变量的比较相等不相等时,把常量放左边更好些
//输出1-100之间的奇数
int main()
{
int i = 1;
while (i <= 100)
{
if (i % 2 == 1)
printf("%d", i);
i++;
}
return 0;
}
int main()
{
int i = 1;
while (i <= 100)
{
printf("%d", i);
i += 2;
}
return 0;
}
30 分支语句switch
常用于多分支的情况
switch()里面是整形表达式
case() 里面是整形常量表达式
31 32 循环语句while
while中遇到break时跳出循环,循环停止
while中遇到continue时跳过此次continue后的代码,继续下次循环
- 循环中只要遇到break,就停止后期的所有的循环,直接终止循环。
- continue是用于终止本次循环,本次循环中continue后边的代码不会再执行,直接跳转到while语句的判断部分,进行下一次循环的入口判断。
ctrl+z 输入EOF
// EOF-end of file -> -1 文件结束标志
//一直读取到\n,然后输出
int ch = 0;
while ((ch = getchar()) != EOF)
{
putchar(ch);
}
应用场景:
int main()
{
//
char password[20] = { 0 };
printf("请输入密码:>");
scanf("%s", password);//123456
//gets
printf("请确认密码(Y/N):>");
//清理缓冲区
//getchar();//处理'\n'
//
//清理缓冲区的中多个字符
int tmp = 0;
while ((tmp = getchar()) != '\n')
{
;
}
int ch = getchar();
if (ch == 'Y')
{
printf("确认成功\n");
}
else
{
printf("确认失败\n");
}
return 0;
}
33 循环语句for
for(初始化部分;条件判断部分;调整部分)
break和continue在for循环中和while循环中是一样的
建议:
1.不可在for循环体内修改循环变量,防止for循环失去控制
2.建议for循环控制变量的取值采用“前闭后开区间”写法(i=0;i<10;i++)
35 循环语句dowhile
练习
//计算n的阶乘
//计算n的阶乘
int main()
{
int ret = 1;
int n = 0;
int i = 0;
printf("请输入要计算的n值:");
scanf("%d", &n);
for (i = 1; i <= n; i++)
{
ret *= i;
}
printf("n的阶乘为:%d\n", ret);
return 0;
}
//计算1!+2!+...+5!
int main()
{
int i = 0;
int n = 0;
int ret = 1;
int sum = 0;
for (n = 1; n <= 5; n++)
{
for (i = 1; i <= n; i++)
{
ret *= i;
}
sum += ret;
ret = 1;
}
printf("sum=%d\n",sum);
return 0;
}
//只用一层循环的方法
int main()
{
int n = 0;
int ret = 1;
int sum = 0;
for (n = 1; n <= 3; n++)
{
ret *= n;
sum += ret;
}
printf("sum=%d\n", sum);
return 0;
}
//二分查找 (在有序数组中查找某个数字n)
int main()
{
int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
int sz= sizeof(arr) / sizeof(arr[0]);//元素个数
int left = 0;//左下标
int right = sz - 1;//右下标
int k = 6;
while (left<=right)
{
int mid = (left + right) / 2;
if (arr[mid] > k)
{
right = mid - 1;
}
else if (arr[mid] < k)
{
left = mid + 1;
}
else
{
printf("下标是%d\n", mid);
break;
}
}
if (left > right)
{
printf("找不到\n");
}
return 0;
}
//多个字符从两端移动,向中间汇聚
#include<string.h>//strlen()
#include<windows.h>//Sleep()
#include<stdlib.h>//system()
int main()
{
char arr1[] = "Together for a Shared Future";
char arr2[] = "############################";
int left = 0;
int right = sizeof(arr1) / sizeof(arr1[0]) - 2;//-2因为数组最后有\0
//int right = strlen(arr1) - 1;
while (left <= right)
{
arr2[left] = arr1[left];
arr2[right] = arr1[right];
printf("%s\n", arr2);
//休息一秒
Sleep(1000);//1000毫秒,头文件#include<windows.h>
system("cls");//system执行系统命令的一个函数-cls清空屏幕,头文件#include<stdlib.h>
left++;
right--;
}
printf("%s\n", arr2);
return 0;
}
//模拟用户登录,只允许输入三次密码,密码正确则提示登录成功;三次均输入错误则退出程序
int main()
{
int i = 0;
char password[20] = { 0 };
for (i = 0; i < 3; i++)
{
printf("请输入密码:>");
scanf("%s", password);
if (strcmp(password, "12345")==0)
{
printf("登陆成功!");
break;
}
else
{
printf("密码错误,重新输入\n");
}
}
if (i == 3)
{
printf("三次错误,退出程序!");
}
return 0;
}
// == 不能用来比较两个字符串是否相等,应该使用一个库函数-strcmp
//库函数strcmp比较两字符串是否相等,相等返回0
strcmp(password,"123456");
//猜数字游戏
1.电脑会生成一个随机数
2.猜数字
#include<stdlib.h>
#include<time.h>
void menu()
{
printf("\n***************************\n");
printf("*******1.play 0.exit******\n");
printf("***************************\n");
}
void game()
{
int i = 0;
//生成一个随机数rand()函数头文件#include<stdlib.h>,生成数范围0~RAND-MAX=32767
//前面需要srand()函数,srand中间需要有unsigned int类型随机数(用时间戳设置生成数的起始点)
//时间戳:当前计算机的时间-计算机的起始时间(1970.1.1 0:0:0)=(xxx)秒
//time函数,头文件#include<time.h>,返回值类型是long
int ret = rand() % 100 + 1;//生成1-100之间的随机数
//printf("随机数是%d\n", ret);
do {
printf("请猜1-100数字:>");
scanf("%d", &i);
if (i < ret)
{
printf("抱歉,猜小了!\n");
}
else if (i > ret)
{
printf("抱歉,猜大了!\n");
}
else
printf("恭喜你,猜对了!数是%d!\n", ret);
} while (i != ret);
}
int main()
{
//猜数字游戏
int input = 0;
srand((unsigned int)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 != 0);
return 0;
}
38 分支循环作业讲解
- define不是关键字,是预处理指令
//将三个数按从大到小输出
int main()
{
int a, b, c = 0;
int tmp = 0;
printf("输入三个整数:");
scanf("%d %d %d", &a, &b, &c);
if (a < b)
{
tmp = a;
a = b;
b = tmp;
}
if (a < c)
{
tmp = a;
a = c;
c = tmp;
}
if(b<c)
{
tmp = b;
b = c;
c = tmp;
}
printf("%d %d %d\n", a, b, c);
return 0;
}
//打印1-100中3的倍数
for(i=1;i<=100;i++)
{
if(i%3==0)
printf("%d",i);
}
//给两个数求最大公因数
//辗转相除法
while (m % n)
{
m = n;
n = (m % n);
}
printf("%d\n", n);
//打印1000-2000之间年份的闰年
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;
}
// if((year % 4 == 0 && year % 100 != 0)|| (year % 400 == 0))
//打印100-200之间的素数
int main()
{
int i = 0;
int count = 0;
for (i = 100; i <= 200; i++)
{
//判断i是否为素数
//素数判断的规则
//1.试除法:产生2->i-1
int j = 0;
for (j = 2; j < i; j++)
{
if (i% j == 0)
{
break;
}
}
if (j == i)
{
count++;
printf("%d ", i);
}
}
printf("\ncount=%d", count);
return 0;
}
更优的方法:当i可以写成i=a*b的形式时,a或b中至少有一个数字<=开平方i
#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++)//sqrt-开平放的数学库函数
{
if (i% j == 0)
{
break;
}
}
if (j>sqrt(i))
{
count++;
printf("%d ", i);
}
}
printf("\ncount=%d", count);
return 0;
}
(继续优化:偶数不可能是素数,在奇数里面找)
for (i = 101; i <= 200; i+=2)
//1-100的所有整数中出现多少个9
for (int i = 1; i <= 100; i++)
{
if (i % 10 == 9)
count++;
if (i / 10 == 9)//不能用else if,否则99的情况只能判断一次
count++;
}
//计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值,打印出结果
int main()
{
int i = 0;
double sum = 0.0;
for (i = 1; i <= 100; i++)
{
if (i % 2 == 0)
sum -= 1.0 / i;
else
sum += 1.0 / i;
}
printf("%lf\n", sum);
return 0;
}
优化:设置flag控制符号变化
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\n", sum);
return 0;
}
//求10个数中的最大值
int arr[] = { 1,3,34,53,64,2,34,23,2,34 };
int max = arr[0];
int i = 0;
int sz = sizeof(arr) / sizeof(arr[0]);
for (i = 1; i < sz; i++)
{
if (arr[i] > max)
{
max = arr[i];
}
}
printf("%d\n", max);
//打印乘法口诀表
int a = 1;
int b = 1;
for (b = 1; b <= 9; b++)//确定打印9行
{
for (a = 1; a <= b; a++)//打印1行的内容
{
printf("%d*%d=%-2d ", b, a, b * a);//左对齐
}
printf("\n");
}