详解C语言中条件判断语句if和switch的用法

if 语句

用 if 语句可以构成分支结构,它根据给的条件进行判定,以决定执行哪个分支程序段。

C 语言的 if 语句有三种基本形式

第一种形式:

if(条件表达式)
{
  语句1;
}

if(条件表达式)
{
  语句1;
}

这种形式运行顺序为:当条件表达式为真,执行语句1,否则,直接跳过语句1,执行后面的语句。

例子1:

BOOL result = YES;
if(result)
{
  printf("result is true\n");
}

BOOL result = YES;
if(result)
{
  printf("result is true\n");
}

输出结果为:

result is true

如果把 result 的值改为 NO,那么就什么都不输出了。

例子2:

int a = 5;
int b = 6;
if(a >= b)
{
  printf("a大于b\n");
}

int a = 5;
int b = 6;
if(a >= b)
{
  printf("a大于b\n");
}

输出结果为:

什么都不输出

如果改成这样:

if(a <= b)
{
  printf("a小于b\n");
}

if(a <= b)
{
  printf("a小于b\n");
}

那么输出结果为:a小于b。

第二种形式:

if(条件表达式)
{
  语句1;
}
else
{
  语句2;
}

if(条件表达式)
{
  语句1;
}
else
{
  语句2;
}

这种结构的执行顺序为:当条件表达式为真时,执行语句1,否则执行语句2。

例子1:

BOOL result= YES;
if(result)
{
  printf("result 为真\n");
}
else
{
  printf("result 为假\n");
}

BOOL result= YES;
if(result)
{
  printf("result 为真\n");
}
else
{
  printf("result 为假\n");
}

这里的两个输出语句绝对不会同时输出。

第三种形式:

if(条件表达式1)
{
  语句1;
}
else if(条件表达式2)
{
  语句2;
}
else
{
  语句3;
}

if(条件表达式1)
{
  语句1;
}
else if(条件表达式2)
{
  语句2;
}
else
{
  语句3;
}

这种结构的执行顺序为:当条件表达式1成立时,执行语句1,如果不成立则看条件表达式2是否成立,如果条件表达式2成立,则执行语句2,如果条件表达式2也不成立这会执行语句3。

例子1:

int age = 35;
if(age < 18)
{
  printf("你是小孩子\n");
}
else if(age >= 60)
{
  printf("你是位老人\n");
}
else
{
  printf("你正当青年啊, 小伙子!\n");
}

int age = 35;
if(age < 18)
{
  printf("你是小孩子\n");
}
else if(age >= 60)
{
  printf("你是位老人\n");
}
else
{
  printf("你正当青年啊, 小伙子!\n");
}

输出结果为:

你正当青年啊,小伙子!

switch语句
上面我们讲了 C 语言中的分支语句其中的 if 语句,今天我们来学习另外一种分支语句:switch 语句。

if 语句的三种形式,大家肯定都还记得,大家回想一下 if 的最后一种形式,如果我们有很多的分支该如何写?难道像这样子吗?

if(条件表达式1)
{
  语句1;
}
else if(条件表达式2)
{
  语句2;
}
else if(条件表达式3)
{
  语句3;
}
else if(条件表达式4)
{
  语句4;
}
else if(条件表达式5)
{
  语句5;
}
else
{
  语句6;
}

如果这样子的话,那么设计C语言也就太不智能了,因此 C 语言中还有另外一种分支语句,就是 switch 语句。结构如下:

switch(整形表达式)
{
  case 值1:
  {
    语句1;
    break;
  }
  case 值2:
  {
    语句2;
    break;
  }
  case 值3:
  {
    语句3;
    break;
  }
  ...
  default:
    默认语句;
    break;
}
switch(整形表达式)
{
  case 值1:
  {
    语句1;
    break;
  }
  case 值2:
  {
    语句2;
    break;
  }
  case 值3:
  {
    语句3;
    break;
  }
  ...
  default:
    默认语句;
    break;
}

说明:

1、首先要注意switch 的语法结构,不能有错误

2、整形表达式的结果值如果等于值1,就执行语句1,如果等于值2,就执行语句2,如果表达式的值与任何 case 都不一样的话,那么就会执行 default 后面的默认语句,也可以没有默认语句,最后结束整个 switch 语句。

3、注意每个语句后面的 break,如果没有 break,break 会跳出当前的 case 语句,从而跳出整个 switch 语句。

4、case 后面的标签只能是整形常量或者整形常量表达式,不能用变量作为 case 的标签。

例子:

int day = 0;
printf("请输入一个 1-7 的数字\n");
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("输入错误\n");
    break;
  }
}

int day = 0;
printf("请输入一个 1-7 的数字\n");
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("输入错误\n");
    break;
  }
}

控制台输出:(我们输入数字2)

请输入一个 1-7 的数字

2

今天是星期二
(0)

相关推荐

  • 用C语言程序判断大小端模式

    1.大端模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中:小端模式相反 2.为什么有大小端之分??? 因为在计算机系统中,存储是以字节为单位的,每个地址单元都对应着一个字节,一个字节=8bit.在C语言中除了8bit的char之外,还有16bit的short型,32bit的long型(要看具体的编译器).对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,如何安排多个字节的存储,这就有了大端存储模式和小端存储模式 3.各自的优势: 小端

  • 使用C语言判断英文字符大小写的方法

    C语言isupper()函数:判断字符是否为大写英文字母 头文件: #include <ctype.h> 定义函数: int isupper(int c); 函数说明:检查参数c是否为大写英文字母. 返回值:若参数c 为大写英文字母,则返回非 0,否则返回 0. 附加说明:此为宏定义,非真正函数. 范例:找出字符串str 中为大写英文字母的字符. #include <ctype.h> main(){ char str[] = "123c@#FDsP[e?"; i

  • 用C语言判断字符是否为空白字符或特殊字符的方法

    C语言isspace()函数:判断字符是否为空白字符 头文件: #include <ctype.h> 定义函数: int isspace(int c); 函数说明:检查参数c是否为空格字符,也就是判断是否为空格(' ').定位字符(' \t ').CR(' \r ').换行(' \n ').垂直定位字符(' \v ')或翻页(' \f ')的情况. 返回值:若参数c 为空白字符,则返回非 0,否则返回 0. 附加说明:此为宏定义,非真正函数. 范例:将字符串str[]中内含的空格字符找出,并显

  • C语言菜鸟基础教程之判断

    (一) 先动手编写一个程序: #include <stdio.h> int main() { if(1) { printf("The condition is true!\n"); } return 0; } 运行结果: The condition is true! 再把1依次改为,2,5,100,-10,发现运行结果完全一样. 再改成if(0),此时发现没有运行结果,说明printf()语句没被执行. C语言把判断语句中的任何非0或非空的值当作真.所以if(1), if(

  • c语言判断是否素数程序代码

    复制代码 代码如下: #include <stdio.h> bool isPrimeNum(int x){    if (x == 1)        return false;    else if (x <= 0)        return false;    else if (x == 2)        return true;    else    {        for (int i = 2; i < x; i++)        {            if (

  • C语言中判断int,long型等变量是否赋值的方法详解

    当然,如果你不赋值给局部变量,这样会导致整个程序的崩溃,因为,它的内容被系统指向了垃圾内存.下面我们看一段代码: 复制代码 代码如下: #include <stdio.h>#include <string.h>#include <stdlib.h>int globle_value;int my_sum(int value1, int value2);long my_sub(long value1, long value2);int main(void){ int aut

  • 使用c语言判断100以内素数的示例(c语言求素数)

    从console输入一个数,判断这个数是否为素数(质数). 复制代码 代码如下: #include <stdio.h> /**判断100以内的素数*/ //定义函数判断是否是素数int isPrime(int num ){    int i;    //从2开始循环,一直到i的平方小于等于给定的数.    for (i = 2; i*i <= num; i++) {        if ( ( num % i ) == 0 ) {            return 0;       

  • C语言小程序 如何判断两个日期之差

    1.普通的写法 复制代码 代码如下: #include <stdio.h>int leapyear(int year){ if((year%4==0 && year%100!=0) || year%400==0)  return 1; else   return 0;}int days(int *day1, int *day2){ int i=0; int *tmp; int diff = 0; const int month[13]={0,31,28,31,30,31,30,

  • C语言判断回文数的小例子

    复制代码 代码如下: #include<stdio.h>#include<stdlib.h> int is_palindrome(char* para_str , int len); int main(int argc , char* argv[]){   int n = atol(argv[2]);     if (is_palindrome(argv[1],n))       printf("this string is palindrome !\n"); 

  • 详解C语言中条件判断语句if和switch的用法

    if 语句 用 if 语句可以构成分支结构,它根据给的条件进行判定,以决定执行哪个分支程序段. C 语言的 if 语句有三种基本形式 第一种形式: if(条件表达式) { 语句1: } if(条件表达式) { 语句1: } 这种形式运行顺序为:当条件表达式为真,执行语句1,否则,直接跳过语句1,执行后面的语句. 例子1: BOOL result = YES: if(result) { printf("result is true\n"); } BOOL result = YES: if

  • 详解C++编程中的条件判断语句if-else与switch的用法

    if-else 语句 控制条件分支. 语法 if ( expression ) statement1 [else statement2] 备注 如果 expression 的值不为零,执行 statement1 .如果选项 else 存在,如果 expression 的值为零,执行 statement2. 表达式必须是算术或指针类型,或者必须是定义明确的整型或指针类型转换的类类型.有关转换器的信息,请参见标准转换. 在两个形式的 if 语句和 expression 语句中计算,可以具有除结构以外

  • 详解R语言中的表达式、数学公式、特殊符号

      在R语言的绘图函数中,如果文本参数是合法的R语言表达式,那么这个表达式就被用Tex类似的规则进行文本格式化. y <- function(x) (exp(-(x^2)/2))/sqrt(2*pi) plot(y, -5, 5, main = expression(f(x) == frac(1,sqrt(2*pi))*e^(-frac(x^2,2))), lwd = 3, col = "blue") library(ggplot2) x <- seq(0, 2*pi, b

  • 详解C语言中动态内存管理及柔性数组的使用

    目录 一.malloc 二.free 三.calloc 四.realloc 1.realloc在扩容时的情况 2.realloc也能实现malloc功能 五.使用动态内存的常见错误 1.free空指针 2.对动态开辟的空间越界访问 3.对非动态开辟内容free 4.只free动态开辟空间的一部分 5.对同一块内存多次free 6.动态内存空间忘记释放(内存泄漏) 六.柔性数组 1.柔性数组的概念 2.柔性数组的特点 3.柔性数组的使用场景 4.柔性数组的优点 一.malloc 这个函数向堆区申请

  • 一文详解C语言中文件相关函数的使用

    目录 一.文件和流 1.程序文件 2.数据文件 3.流 二.文件组成 三.文件的打开和关闭 1.文件的打开fopen 2.文件关闭fclose 四.文件的顺序读写 1.使用fputc和fgetc写入/读取单个字符 2.使用fputs和fgets写入/读取一串字符 3.使用fprintf和fscanf按照指定的格式写入/读取 4.使用fwrite和fread按照二进制的方式写入/读取 5.使用sprintf和sscanf将格式化数据和字符串互相转换(文件无关) 五.文件的随机读写 1.fseek(

  • 详解R语言中的多项式回归、局部回归、核平滑和平滑样条回归模型

    在标准线性模型中,我们假设 .当线性假设无法满足时,可以考虑使用其他方法. 多项式回归 扩展可能是假设某些多项式函数, 同样,在标准线性模型方法(使用GLM的条件正态分布)中,参数  可以使用最小二乘法获得,其中  在  . 即使此多项式模型不是真正的多项式模型,也可能仍然是一个很好的近似值 .实际上,根据 Stone-Weierstrass定理,如果  在某个区间上是连续的,则有一个统一的近似值  ,通过多项式函数. 仅作说明,请考虑以下数据集 db = data.frame(x=xr,y=y

  • 详解C语言中二分查找的运用技巧

    目录 基础的二分查 查找左侧边界 查找右侧边界 二分查找问题分析 实例1: 爱吃香蕉的珂珂 实例2:运送包裹 前篇文章聊到了二分查找的基础以及细节的处理问题,主要介绍了 查找和目标值相等的元素.查找第一个和目标值相等的元素.查找最后一个和目标值相等的元素 三种情况. 这些情况都适用于有序数组中查找指定元素 这个基本的场景,但实际应用中可能不会这么直接,甚至看了题目之后,都不会想到可以用二分查找算法来解决 . 本文就来分析下二分查找在实际中的应用,通过分析几个应用二分查找的实例,总结下能使用二分查

  • 详解Go语言中的作用域和变量隐藏

    目录 前言 包隐藏 全局变量 类型强制 闭包 := 的情况 总结 前言 变量隐藏在 Go 中可能会令人困惑,让我们尝试弄清楚. package main import ( "fmt" "io/ioutil" "log" ) func main() { f, err := ioutil.TempFile("", "") if err != nil { log.Fatal(err) } defer f.Clos

  • 详解Go语言中泛型的实现原理与使用

    目录 前言 问题 解决方法 类型约束 重获类型安全 泛型使用场景 性能 虚拟方法表 单态化 Go 的实现 结论 前言 原文:A gentle introduction to generics in Go byDominik Braun 万俊峰Kevin:我看了觉得文章非常简单易懂,就征求了作者同意,翻译出来给大家分享一下. 本文是对泛型的基本思想及其在 Go 中的实现的一个比较容易理解的介绍,同时也是对围绕泛型的各种性能讨论的简单总结.首先,我们来看看泛型所解决的核心问题. 问题 假设我们想实现

  • 详解C语言中双向循环链表的实现

    目录 实现细节 辅助理解图 具体实现代码 1.对链表进行初始化 2.任意位置前的插入 3.任意位置的删除 4.头插和尾删 完整代码 头文件 具体函数 测试 实现细节 1.带一个哨兵位(哨兵节点,初始节点,不存储有效数据,用来方便后期数据的存储与查找) 2.与单向链表不同的是,双向链表中每个数据节点包含两个指针,分别指向前后两个节点 3.双向链表是循环的,其尾节点后不是空指针,而是与头部的哨兵节点通过指针相连 辅助理解图 具体实现代码 1.对链表进行初始化 初始化:哨兵位的前后指针均指向哨兵节点本

随机推荐