认识C语言 Day_4 >语句、结构

简介: 认识C语言 Day_4 >语句、结构

小知识

scanf输入数据问题

1.scanf各种不同类型数据的介绍

%c(字符),%d(整型),%f(float),%lf(double),%s(字符串)

注意:输入的格式要跟数据类型匹配

2.scanf格式后面不要加'\n'

'\n'是打印的时候换行,输入的时候不需要加'\n'

1.语句

1.1简单介绍

C语言是一种结构化的程序设计语言,它有三种结构:顺序结构,选择结构,循环结构

  • 顺序结构:简单说就是从头到尾,一条路走到头
  • 选择结构:简单说就是到一个路口进行多个选择
  • 循环结构:简单说就是循环执行一段语句

生活中的任何一件事都可以抽象成这三种结构中的一种或者组合,所以用C语言来写代码,用这三种结构,基本就可以描述生活中的每一个场景了

2.选择结构

C语言中提供了两种选择语句

  • if语句
  • switch语句

2.1 if语句

2.1.1 if-else表达式

if (表达式)
   语句1;
else
   语句2;

如果满足表达式,即表达式为真,则执行语句1;

若不满足表达式,即表达式为假,则执行语句2。

那何为真假呢?

0表示假,非0表示真

2.1.2 简单的代码示例

if就是是否、如果的意思,表示判断,比如下面这段代码,他的意思是

判断a的值是1还是0

  • 如果a等于1,则printf("提升自己\n");
  • 否则(如果a等于0),则printf("无法就业\n");

应该是很容易理解的

#define _CRT_SECURE_NO_WARNINGS 1
#include "stdio.h"
int main()
{
  int a;
  printf("恭喜进入大学\n");
  printf("你打算好好学习吗?\n");
  printf("1.好好学习   0.不好好学习\n");
  scanf("%d", &a);
  if (a==1)//判断a的值
  {
    printf("提升自己\n");
  }
  else
  {
    printf("无法就业\n");
  }
  return 0;
}

2.1.3多分支if-else if-...-else

//多分支
if (表达式1)
       语句1;
else if (表达式2)
       语句2;
else
       语句3;

这是if-else语句的升级版,多了几个分支,同样如果表达式1为真,则执行语句1;表达式2为真,则执行语句2;否则,执行语句3

当然,依照这样的代码,根据选择条件,我们可以有若干个分支

2.1.4 单条语句与多条语句

当我们要写多条语句时,要用到{},将代码括起来。如下

if  (a==1)
{
    printf("提升自己\n");
    printf("成为大佬\n");
}
else
{
    printf("自暴自弃");
    printf("自暴自弃");
}

注意else的匹配:else是和它离的最近的if匹配的

2.1.5 注意

多分支语句的执行顺序

  • 从上到下依次判断,若符合 if 条件,就执行if下面的语句;若不符合 if ,就看是否满足下一条 else if 的条件;直到找出符合条件的为止,若所有条件都不符合,就执行 else 的语句。
  • if的表达式为判断是否相等,判断是否相等的符号为"=="而不是"="

if (a=1)

这样一来就不是判断了,而是将1赋值给a!!!

因此我们要写成下面这样

if (a==1)

2.2 switch语句

switch语句从字面上讲,可以称为开关语句,是一种多分支选择结构,一般与case、break、default配合使用,对流程进行控制。

2.2.1 switch-case表达式

switch(表达式){ 
  case 常量表达式1:  语句1;
  case 常量表达式2:  语句2;
  …… 
  case 常量表达式n:  语句n;
  default:  语句n+1;
}

其中switch、case、break、default都是关键词。

switch作为一个开关

  • 当变量表达式的值对应case中的值时,执行case后面的语句后跳出switch语句
  • 如果都不符合则执行default后面的语句后跳出switch语句

2.2.2 简单的代码示例

switch语句常常用于多分支的情况。

这种多分支,一般指的是很多很多分支,用if-else来书写非常麻烦,且判定条件主要以整型为主:

如:输入数字,输出相应的星期几

#include <stdio.h>
int main()
{
  int day = 0;
    printf("请输入:");
    scanf("%d", &day);
    switch (day) {
    case 1:
      printf("星期一\n");
      break;
    case 2:
      printf("星期二\n");
      break;
    case 3:
      printf("星期三\n");
      break;
    case 4:
      printf("星期四\n");
      break;
    case 5:
      printf("星期五\n");
      break;
    case 6:
      printf("星期六\n");
      break;
    case 7:
      printf("星期天\n");
      break;
        default:
            printf("Error\n");
  } 
  return 0;
}

2.2.3switch语句规则

switch语句非常有用,但在使用时必须谨慎。所写的任何switch语句都必须遵循以下规则:

  • 只能针对基本数据类型中的整型类型使用switch,这些类型包括int、char等。对于其他类型,则不能使用switch语句。
  • switch()的参数类型不能为实型 。因为switch后面只能带自动转换为整形(包括整形)的类型,比如字符型char,unsigned int等,实数型不能自动转换为整形。
  • case标签必须是常量表达式(constantExpression),如62或者’8’等。
  • case标签必须是唯一性的表达式;也就是说,不允许两个case具有相同的值
  • 在case后,允许有多个语句,可以不用{}括起来。
  • 各case和default句的先后顺序可以变动,而不会影响程序执行结果。
  • default子句可以省略不用。

3.循环结构

C语言中提供了三种循环语句

  • while循环
  • for循环
  • do...while循环

3.1 while循环

while语句可以在条件表达式为真的情况下,循环执行指定的一段代码,直到表达式不为真的时结束。

3.1.1 while语句表达式

while(表达式)
{
    语句块
}
  • 先执行while(表达式),条件为真,则执行语句块
  • 执行完语句块,回到while(表达式)继续执行
  • 直到表达式为假,才退出循环,执行while后面的代码

3.1.2简单代码示例

#include <stdio.h>
int main (void)
{
  int i=0;    //初始条件i=0;
  while(i<10)  //while 循环
        //while(表达式) 如果为真执行{  }里面语句块。
  {
    printf("i的值为:%d\n",i); //输出i的值
    i++;    //自增
  }
  return 0;
}

这段代码是输出0-9的数

3.2 for循环

for循环是一种常用的shell编程语句,用于重复执行一段代码块,直到满足某个条件为止。

for循环通常用于遍历数组、文件列表等场景

3.2.1 for循环语句表达式

for (表达式 1 ;表达式 2 ;表达式 3) { 
    若干语句;
}
  • 初次循环执行表达式1,执行表达式2,在表达式2为true的前提下执行“若干语句”,执行表达式3
  • 执行表达式2,在表达式2为true的前提下执行“若干语句”,执行表达式3
  • ……
  • 依次的执行下去,直到表达式3的值不能使表达式2为true时,for循环结束

3.2.2 简单的代码示例

日常代码输出

#include <stdio.h>
int main( ){
    printf("爱惜粮食,从一粒米开始\n");
    printf("爱惜粮食,从一粒米开始\n");
    printf("爱惜粮食,从一粒米开始\n");
    printf("爱惜粮食,从一粒米开始\n");
    printf("爱惜粮食,从一粒米开始\n");
    printf("爱惜粮食,从一粒米开始\n");
    printf("爱惜粮食,从一粒米开始\n");
    printf("爱惜粮食,从一粒米开始\n");
    printf("爱惜粮食,从一粒米开始\n");
    printf("爱惜粮食,从一粒米开始\n");
}

用for循环输出

#include <stdio.h>
int main(){
  int i ;
  for (i=1;i<=10;i++)
    printf("爱惜粮食,从一粒米开始\n");
}

3.3 do...while循环

do while循环语句是一种循环控制语句

在执行循环体之前先判断循环条件。即无论循环条件是否成立,先执行循环体中的语句,然后再判断循环条件是否成立,如果成立则继续执行循环体,直到循环条件不成立时结束循环。

与while循环不同的是,do while循环保证循环体至少执行一次。

3.3.1 do...while循环语句表达式

do 
{
循环体;
} 
while (循环条件);

3.3.2 简单的代码示例

用do-while输出1到10的值

#include <stdio.h>
int main (void)
{ 
  int i = 1;  // 设置初始值,i为1。
  do      
  {
    printf("数值为:%d\n",i);
    i++;
  }
  while(i<=10);   //先执行语句,在判断结果。
  return 0;
}

4.结束

那么今天的学习就到这里咯,今天我们学到了两种结构、五种语句的知识

小杜跟各位小伙伴在一起成长,祝我们都能成为大牛!

                                                                                                                               //小杜的成长之路

相关文章
|
1月前
|
网络协议 编译器 Linux
【C语言】结构体内存对齐:热门面试话题
【C语言】结构体内存对齐:热门面试话题
|
20天前
|
存储 搜索推荐 算法
【数据结构】树型结构详解 + 堆的实现(c语言)(附源码)
本文介绍了树和二叉树的基本概念及结构,重点讲解了堆这一重要的数据结构。堆是一种特殊的完全二叉树,常用于实现优先队列和高效的排序算法(如堆排序)。文章详细描述了堆的性质、存储方式及其实现方法,包括插入、删除和取堆顶数据等操作的具体实现。通过这些内容,读者可以全面了解堆的原理和应用。
60 16
|
5月前
|
C语言
【C语言基础篇】结构控制(中)循环结构
【C语言基础篇】结构控制(中)循环结构
|
1月前
|
编译器 C语言 Python
C语言结构
C语言结构
17 0
|
2月前
|
存储 编译器 程序员
C语言程序的基本结构
C语言程序的基本结构包括:1)预处理指令,如 `#include` 和 `#define`;2)主函数 `main()`,程序从这里开始执行;3)函数声明与定义,执行特定任务的代码块;4)变量声明与初始化,用于存储数据;5)语句和表达式,构成程序基本执行单位;6)注释,解释代码功能。示例代码展示了这些组成部分的应用。
96 10
|
2月前
|
C语言
C语言程序设计核心详解 第四章&&第五章 选择结构程序设计&&循环结构程序设计
本章节介绍了C语言中的选择结构,包括关系表达式、逻辑表达式及其运算符的优先级,并通过示例详细解释了 `if` 语句的不同形式和 `switch` 语句的使用方法。此外,还概述了循环结构,包括 `while`、`do-while` 和 `for` 循环,并解释了 `break` 和 `continue` 控制语句的功能。最后,提供了两道例题以加深理解。
|
2月前
|
存储 算法 C语言
数据结构基础详解(C语言): 二叉树的遍历_线索二叉树_树的存储结构_树与森林详解
本文从二叉树遍历入手,详细介绍了先序、中序和后序遍历方法,并探讨了如何构建二叉树及线索二叉树的概念。接着,文章讲解了树和森林的存储结构,特别是如何将树与森林转换为二叉树形式,以便利用二叉树的遍历方法。最后,讨论了树和森林的遍历算法,包括先根、后根和层次遍历。通过这些内容,读者可以全面了解二叉树及其相关概念。
|
2月前
|
C语言
C语言程序设计核心详解 第三章:顺序结构,printf(),scanf()详解
本章介绍顺序结构的基本框架及C语言的标准输入输出。程序从`main()`开始依次执行,框架包括输入、计算和输出三部分。重点讲解了`printf()`与`scanf()`函数:`printf()`用于格式化输出,支持多种占位符;`scanf()`用于格式化输入,需注意普通字符与占位符的区别。此外还介绍了`putchar()`和`getchar()`函数,分别用于输出和接收单个字符。
|
2月前
|
存储 机器学习/深度学习 C语言
数据结构基础详解(C语言): 树与二叉树的基本类型与存储结构详解
本文介绍了树和二叉树的基本概念及性质。树是由节点组成的层次结构,其中节点的度为其分支数量,树的度为树中最大节点度数。二叉树是一种特殊的树,其节点最多有两个子节点,具有多种性质,如叶子节点数与度为2的节点数之间的关系。此外,还介绍了二叉树的不同形态,包括满二叉树、完全二叉树、二叉排序树和平衡二叉树,并探讨了二叉树的顺序存储和链式存储结构。
|
3月前
|
C语言
C语言------选择结构
这篇文章是C语言选择结构的入门实训,包括多个练习题及其源代码,旨在帮助读者熟练掌握条件语句和选择结构程序设计方法,并熟悉switch语句和程序调试过程。
C语言------选择结构