大家好,我是深鱼~
目录
前言:
1.switch语句
2.从大到小输出
3.打印素数
4.打印闰年
5.最大公约数
(1)题解1:辗转相除法
(2)题解2:更相减损法
6.乘法口诀表
7.求最大值
8.分数求和
总结:
结语:
本篇适合于初次学习分支语句和循环语句的同学学习,这些编程题都是一些经典必会题,如果你做过,看看还有没有第二种方法,然后看看什么方法最优,欢迎评论区交流学习
题目:
关于switch说法不正确的是:( )
A.switch语句中的default子句可以放在任意位置
B.switch语句中case后的表达式只能是整形常量表达式
C.switch语句中case子句必须在default子句之前
D.switch语句中case表达式不要求顺序
题解:
正确答案是:C
ACD.case和default表达式可以放在任何位置,但是最好还是case在前,default在后
B.switch语句中case后的表达式只能是整形常量表达式,整形常量表达式指的是表达式中的操作数都是整数类型的,这里的整数类型不仅仅是int类型,还包括char, short,long等类型,switch后面也是这些类型
题目:
写代码将三个整数数按从大到小输出。
例如:
输入:2 3 1
输出:3 2 1
题解:思路:始终让a>b>c,如果条件不满足就交换大小,这样就需要比较三组,a和b,a和c,b和c,三个if语句解决.
但是如果是多个整数,就需要冒泡排序,或者qsort函数,如果想学习,可以看看C语言编程入门之刷题篇(四)第四题:争夺前五名
#include
int main()//从大到小输出
{
int a = 0;
int b = 0;
int c = 0;
//输入
scanf("%d %d %d", &a, &b, &c);
//比较并换位:始终让a>b>c
if (a < b)
{
//交换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", a, b, c);
return 0;
}
题目:
写一个代码:打印100~200之间的素数
题解:思路就是生成100到200之间的数,然后用除数j去除,如果被除数i被整除了,就直接跳出循环,如果j大于sqrt(i)还没被整除,i就是素数
注意几点:
<1>因为素数个位只能是以1,3,5,7,9,所以生成被除数可以直接初始化个位为1,然后不断加2(i=i+2)(但是注意2是特殊情况)
<2>除数j是从2开始,而不是从1开始(任何数都可以被1整除)
<3>除数j到sqrt(i)(i的平方根)还没被整除就说明是素数
<4>打印素数要在循环外部,如果j大于sqrt(i),就是素数
#include
#include
int main()//打印100~200之间的素数
{
int i = 0;//被除数
int j = 0;//除数
//素数个位只能是以1,3,5,7,9
for (i = 101; i <= 200; i = i + 2)
{
//判断是否是素数
for (j = 2; j <= sqrt(i); j++)//注意这里除数j是从2开始的
{
//如果i被整除,直接跳出循环
if (i % j == 0)
break;
}
//如果没有j可以整除i,即j>sqrt(i),就是素数
if (j > sqrt(i))
printf("%d ", i);
}
return 0;
}
题目:
打印1000年到2000年之间的闰年
题解:判断条件:能被4整除,但是不能被100整除,再闰或者能被400整除
((year % 4 == 0) && (year % 100 != 0))|| (year % 400 == 0)
#include
int main()//打印1000年到2000年之间的闰年
{
int year = 0;
//生成年
for (year = 1000; year <= 2000; year++)
{
//判断:能被4整除,但是不能被100整除,再闰或者能被400整除
if (((year % 4 == 0) && (year % 100 != 0))|| (year % 400 == 0))
//输出
printf("%d ", year);
}
return 0;
}
运行结果:没有1100,1300,1400,1500,1700,1800,1900
题目:
给定两个数,求这两个数的最大公约数
例如:
输入:20 40
输出:20
思路:(这里不需要考虑a和b的大小关系,如果b>a进入一次循环以后a就会大于b了
两整数相余a%b=c;
如果c==0则b为最大公约数;
如果c!=0则让a=b,b=c;
然后继续a%b看是否为0,为0直接输出b,不为0再循环
举例:
a=28,b=21 a=21,b=28
c=a%b=7(c!=0) c=a%b=21(c!=0)
a=b=21; a=b=28
b=c=7; b=c=21(这时候a和b交换了)
c=a%b=0
直接输出b=7(最大公约数)
#include
int main()//给定两个数,求这两个数的最大公约数:辗转相除法
{
int a = 0;
int b = 0;
int c = 0;
//输入
scanf("%d %d", &a, &b);
//求最大公约数
while (c = a % b)
{
a = b;
b = c;
}
//输出
printf("%d", b);
return 0;
}
思路:
如果a>b,则a=a-b;
如果b>a,则b=b-a;
然后看a是否等于b,如果相等最大公约数就是a,
如果不相等继续循环a=a-b或b=b-a
举例:
a=28,b=21
a=a-b=7(b>a)
b=b-a=14(b>a)
b=b-a=7(a==b)
直接输出a
#include
int main()//更相减损法
{
int a = 0;
int b = 0;
int i = 0;
//输入
scanf("%d %d", &a, &b);
//求最大公约数
while (a != b)
{
if (a > b)
a = a - b;
if (b > a)
b = b - a;
}
//当a==b时输出a或b
printf("%d", a);
return 0;
}
题目:
在屏幕上输出9*9乘法口诀表
题解:嵌套循环问题:i和j分别代表一个乘数,一个i结束记得换行
这里的%-2d:
%2d表示使输出的int型的数值以2位的固定位宽输出,如果不足2位,则在前面补空格;
%-2d表示使输出的int型的数值以2位的固定位宽输出,如果不足2位,数字在前,空格补后面
#include
int main()//输出9*9乘法口诀表
{
int i = 0;//乘数1
for (i = 1; i <= 9; i++)
{
int j = 0;//乘数2
for (j = 1; j <= i; j++)
{
//输出
printf("%d*%d=%-2d ", i, j, i * j);
}
printf("\n");//换行
}
return 0;
}
程序结果:
题目:
求10 个整数中最大值
题解:本题和C语言编程入门之刷题篇(四)第7题最高分数方法一样,只不过这里数字比较大得数组输入,最高分数只是三个数,直接输入即可,本质没区别
#include
int main()//求10 个整数中最大值
{
int arr[10] = { 0 };
int i = 0;
//输入数组
for (i = 0; i < 10; i++)
{
scanf("%d", &arr[i]);
}
//比较
int max = arr[0];//首先认定第一个数为最大
//从第二个数开始比较,然后比max大,就让这个数为max
for (i = 1; i < 10; i++)
{
if (arr[i] > max)
max = arr[i];
}
//输出
printf("%d", max);
return 0;
}
题目:
计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值,打印出结果
题解:本题和C语言编程入门之刷题篇(四)第一题计算平均成绩sum/5.0和第三题网购flag*50有异曲同工之妙,注意这里的一个怎么变换符号的,flag=-flag
#include
int main()//计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值,打印出结果
{
int i = 0;
double sum = 0.0;
int flag = 1;
//计算
for (i = 1; i <= 100; i++)
{
sum += 1.0 / i*flag;
flag = -flag;
}
//输出
printf("%lf", sum);
return 0;
}
程序结果:
1.switch语句中case和switch后面接的不一定只是int类型,还可以是char,short,long类型,但是不能跟double,float类型
2.数按从大到小输出:
如果数较少,就始终让a>b>c,如果不满足就交换位置
如果数较多,就冒泡排序或者qsort函数
3.打印100-200之间的素数:
生成数i可以初始化个位为1,然后i=i+2
j初始化为2,j只需要到sqrt(i)即可
怎么结束判断,j>=sqrt(i)输出i即可
4.闰年的判断:(((year%4==0)&&(year%100!=0))||(year%400==0))
5.最大公约数:
(1)辗转相除法:c=a%b a=b b=c
(2)更相减损法:a!=b a=a-b b=b-a
6.打印乘法口诀表:理解%-2d
7.求几个数最大值:让第一个数为max,然后遍历比较
8.分数计算:运用1.0/i和*flag的方法
感觉笔者写的还可以,或者自己有些许收获的时候,麻烦铁汁们动动小手,给俺来个一键三连,万分感谢