C语言分支语句和循环语句经典题及易错题

2023-11-11 01:59

本文主要是介绍C语言分支语句和循环语句经典题及易错题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

大家好,我是深鱼~

目录

前言:

1.switch语句

2.从大到小输出

3.打印素数

4.打印闰年

 5.最大公约数

(1)题解1:辗转相除法

(2)题解2:更相减损法

6.乘法口诀表

 7.求最大值

 8.分数求和

 总结:

结语:


前言:

本篇适合于初次学习分支语句和循环语句的同学学习,这些编程题都是一些经典必会题,如果你做过,看看还有没有第二种方法,然后看看什么方法最优,欢迎评论区交流学习

1.switch语句

题目:

关于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.从大到小输出

题目:

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

例如:

输入:2 3 1

输出:3 2 1

题解:思路:始终让a>b>c,如果条件不满足就交换大小,这样就需要比较三组,a和b,a和c,b和c,三个if语句解决.

但是如果是多个整数,就需要冒泡排序,或者qsort函数,如果想学习,可以看看C语言编程入门之刷题篇(四)第四题:争夺前五名

#include<stdio.h>
int main()//从大到小输出
{int a = 0;int b = 0;int c = 0;//输入scanf("%d %d %d", &a, &b, &c);//比较并换位:始终让a>b>cif (a < b){//交换a和bint 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;
}

3.打印素数

题目:

写一个代码:打印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<stdio.h>
#include<math.h>
int main()//打印100~200之间的素数
{int i = 0;//被除数int j = 0;//除数//素数个位只能是以1,3,5,7,9for (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;
}

4.打印闰年

题目:

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

题解:判断条件:能被4整除,但是不能被100整除,再闰或者能被400整除

                       ((year % 4 == 0) && (year % 100 != 0))|| (year % 400 == 0)

#include<stdio.h>
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

 5.最大公约数

题目:

给定两个数,求这两个数的最大公约数

例如:

输入:20 40

输出:20

(1)题解1:辗转相除法

思路:(这里不需要考虑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<stdio.h>
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;
}

(2)题解2:更相减损法

思路:

如果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<stdio.h>
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或bprintf("%d", a);return 0;
}

6.乘法口诀表

题目:

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

题解:嵌套循环问题:i和j分别代表一个乘数,一个i结束记得换行

这里的%-2d

%2d表示使输出的int型的数值以2位的固定位宽输出,如果不足2位,则在前面补空格;

%-2d表示使输出的int型的数值以2位的固定位宽输出,如果不足2位,数字在前,空格补后面

#include<stdio.h>
int main()//输出9*9乘法口诀表
{int i = 0;//乘数1for (i = 1; i <= 9; i++){int j = 0;//乘数2for (j = 1; j <= i; j++){//输出printf("%d*%d=%-2d ", i, j, i * j);}printf("\n");//换行}return 0;
}

程序结果:

 7.求最大值

题目:

求10 个整数中最大值

题解:本题和C语言编程入门之刷题篇(四)第7题最高分数方法一样,只不过这里数字比较大得数组输入,最高分数只是三个数,直接输入即可,本质没区别

#include<stdio.h>
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大,就让这个数为maxfor (i = 1; i < 10; i++){if (arr[i] > max)max = arr[i];}//输出printf("%d", max);return 0;
}

 8.分数求和

题目:

计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值,打印出结果

题解:本题和C语言编程入门之刷题篇(四)第一题计算平均成绩sum/5.0和第三题网购flag*50有异曲同工之妙,注意这里的一个怎么变换符号的,flag=-flag

#include<stdio.h>
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的方法

结语:  彼方尚有荣光在,少年不惧岁月长

感觉笔者写的还可以,或者自己有些许收获的时候,麻烦铁汁们动动小手,给俺来个一键三连,万分感谢

这篇关于C语言分支语句和循环语句经典题及易错题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

好题——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)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

poj3750约瑟夫环,循环队列

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

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

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

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而

C语言:柔性数组

数组定义 柔性数组 err int arr[0] = {0}; // ERROR 柔性数组 // 常见struct Test{int len;char arr[1024];} // 柔性数组struct Test{int len;char arr[0];}struct Test *t;t = malloc(sizeof(Test) + 11);strcpy(t->arr,

C语言指针入门 《C语言非常道》

C语言指针入门 《C语言非常道》 作为一个程序员,我接触 C 语言有十年了。有的朋友让我推荐 C 语言的参考书,我不敢乱推荐,尤其是国内作者写的书,往往七拼八凑,漏洞百出。 但是,李忠老师的《C语言非常道》值得一读。对了,李老师有个官网,网址是: 李忠老师官网 最棒的是,有配套的教学视频,可以试看。 试看点这里 接下来言归正传,讲解指针。以下内容很多都参考了李忠老师的《C语言非

C 语言基础之数组

文章目录 什么是数组数组变量的声明多维数组 什么是数组 数组,顾名思义,就是一组数。 假如班上有 30 个同学,让你编程统计每个人的分数,求最高分、最低分、平均分等。如果不知道数组,你只能这样写代码: int ZhangSan_score = 95;int LiSi_score = 90;......int LiuDong_score = 100;int Zhou