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

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

前言:

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

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>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;
}

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,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;
}

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或b
  printf("%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;//乘数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;
}

程序结果:

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大,就让这个数为max
  for (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的方法


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


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


目录
相关文章
|
12月前
|
C语言
C语言分支和循环语句
分支语句由`if-else`构成,用于根据不同条件执行相应代码。`else`会与最近未配对的`if`结合,多个条件可用`else if`实现。若连续使用`if`,各条件互不影响。嵌套结构可在`if`中再加入`if-else`。此外,`switch`语句适用于多分支选择(注意表达式不能为浮点数,`case`后需加`break`)。循环语句包括`for`、`while`和`do...while`,注意`do...while`末尾需加分号。循环中,`break`直接终止循环,`continue`跳过当前循环剩余部分,但`for`的语句三仍会执行,而`while`中位置影响效果。
252 0
|
人工智能 Java 程序员
一文彻底搞清楚C语言的循环语句
本文介绍了C语言中的三种循环语句:`while`、`do-while`和`for`,并详细解释了它们的语法格式、执行流程及应用场景。此外,还讲解了循环控制语句`break`和`continue`的使用方法。希望这些内容能帮助你在编程道路上不断进步,共同成长!
1597 0
一文彻底搞清楚C语言的循环语句
|
C语言
【C语言程序设计——循环程序设计】枚举法换硬币(头歌实践教学平台习题)【合集】
本文档介绍了编程任务的详细内容,旨在运用枚举法求解硬币等额 - 循环控制语句(`for`、`while`)及跳转语句(`break`、`continue`)的使用。 - 循环嵌套语句的基本概念和应用,如双重`for`循环、`while`嵌套等。 3. **编程要求**:根据提示在指定区域内补充代码。 4. **测试说明**:平台将对编写的代码进行测试,并给出预期输出结果。 5. **通关代码**:提供完整的代码示例,帮助理解并完成任务。 6. **测试结果**:展示代码运行后的实际输出,验证正确性。 文档结构清晰,逐步引导读者掌握循环结构与嵌套的应用,最终实现硬币兑换的程序设计。
272 19
|
算法 C语言
【C语言程序设计——循环程序设计】求解最大公约数(头歌实践教学平台习题)【合集】
采用欧几里得算法(EuclideanAlgorithm)求解两个正整数的最大公约数。的最大公约数,然后检查最大公约数是否大于1。如果是,就返回1,表示。根据提示,在右侧编辑器Begin--End之间的区域内补充必要的代码。作为新的参数传递进去。这个递归过程会不断进行,直到。有除1以外的公约数;变为0,此时就找到了最大公约数。开始你的任务吧,祝你成功!是否为0,如果是,那么。就是最大公约数,直接返回。
484 18
|
Serverless C语言
【C语言程序设计——循环程序设计】利用循环求数值 x 的平方根(头歌实践教学平台习题)【合集】
根据提示在右侧编辑器Begin--End之间的区域内补充必要的代码,求解出数值x的平方根;运用迭代公式,编写一个循环程序,求解出数值x的平方根。注意:不能直接用平方根公式/函数求解本题!开始你的任务吧,祝你成功!​ 相关知识 求平方根的迭代公式 绝对值函数fabs() 循环语句 一、求平方根的迭代公式 1.原理 在C语言中,求一个数的平方根可以使用牛顿迭代法。对于方程(为要求平方根的数),设是的第n次近似值,牛顿迭代公式为。 其基本思想是从一个初始近似值开始,通过不断迭代这个公式,使得越来越接近。
470 18
|
C语言
【C语言程序设计——循环程序设计】统计海军鸣放礼炮声数量(头歌实践教学平台习题)【合集】
有A、B、C三艘军舰同时开始鸣放礼炮各21响。已知A舰每隔5秒1次,B舰每隔6秒放1次,C舰每隔7秒放1次。编程计算观众总共听到几次礼炮声。根据提示,在右侧编辑器Begin--End之间的区域内补充必要的代码。开始你的任务吧,祝你成功!
365 13
|
存储 C语言
【C语言程序设计——循环程序设计】利用数列的累加和求 sinx(头歌实践教学平台习题)【合集】
项的累加和,一般会使用循环结构,在每次循环中计算出当前项的值(可能基于通项公式或者递推关系),然后累加到一个用于存储累加和的变量中。在C语言中推导数列中的某一项,通常需要依据数列给定的通项公式或者前后项之间的递推关系来实现。例如,对于一个简单的等差数列,其通项公式为。的级数,其每一项之间存在特定的递推关系(后项的分子是其前项的分子乘上。,计算sinx的值,直到最后一项的绝对值小于。为项数),就可以通过代码来计算出指定项的值。对于更复杂的数列,像题目中涉及的用于近似计算。开始你的任务吧,祝你成功!
414 6
|
C语言
【C语言程序设计——循环程序设计】鸡兔同笼问题(头歌实践教学平台习题)【合集】
本教程介绍了循环控制和跳转语句的使用,包括 `for`、`while` 和 `do-while` 循环,以及 `break` 和 `continue` 语句。通过示例代码详细讲解了这些语句的应用场景,并展示了如何使用循环嵌套解决复杂问题,如计算最大公因数和模拟游戏关卡选择。最后,通过鸡兔同笼问题演示了穷举法编程的实际应用。文中还提供了编程要求、测试说明及通关代码,帮助读者掌握相关知识并完成任务。 任务描述:根据给定条件,编写程序计算鸡和兔的数量。鸡有1个头2只脚,兔子有1个头4只脚。
841 5
|
C语言
【c语言】分支语句
C语言通过三种基本结构——顺序、选择和循环,构建复杂的程序逻辑。本文主要介绍了C语言的选择结构,即if-else语句及其变体,包括简单的if语句、if-else组合、else if多分支判断、嵌套if以及解决悬空else问题的方法。此外,还详细讲解了逻辑运算符和关系运算符的使用,以及如何利用条件操作符简化逻辑判断。最后,文章对比了if-else与switch语句在实现多分支逻辑时的应用,并解释了switch语句中的break和default关键字的作用。
343 8
|
C语言
【c语言】循环语句
循环结构是C语言中用于简化重复操作的重要工具,主要包括while循环、do-while循环和for循环。while循环是最基本的形式,通过不断检查条件来决定是否继续执行循环体。do-while循环则先执行循环体,再检查条件,至少执行一次。for循环逻辑更复杂,但使用频率最高,适合初始化、条件判断和更新变量的集中管理。此外,循环中还可以使用break和continue语句来控制循环的提前终止或跳过当前迭代。最后,循环可以嵌套使用,解决更复杂的问题,如查找特定范围内的素数。
451 6