C语言笔记:控制流

news2025/1/17 4:01:27

 ACM金牌带你零基础直达C语言精通-课程资料

 本笔记属于船说系列课程之一,课程链接:ACM金牌带你零基础直达C语言精通

你也可以选择购买『船说系列课程-年度会员』产品『船票』,畅享一年内无限制学习已上线的所有船说系列课程:船票购买入口

一.条件表达式

        什么是条件表达式,由关系运算符组成的表达式就叫做条件表达式;

        C语言关系运算符

        代码演示:
int main() {
    int a, b;
    scanf("%d%d", &a, &b);
    //输出每个条件表达式对应的整形值
    printf("a == b (%d)\n",     a == b);
    printf("a != b (%d)\n",     a != b);
    printf("a < b (%d)\n",      a < b);
    printf("a > b (%d)\n",      a > b);
    printf("a <= b (%d)\n",     a <= b);
    printf("a >= b (%d)\n",     a >= b);
    printf("!(a == b) (%d)\n", !(a == b));
    printf("a = %d\n", a);
    //看关系表达式对应整形值是否可以参与运算
    a += (a == b);
    printf("a = %d\n", a);

    //实践判断逻辑与和逻辑或的判断逻辑
    printf("a < b && a == 3 (%d)\n", a < b && a == 3);
    printf("a < b || a == 3 (%d)\n", a < b || a == 3);
    printf("1 && 1 (%d)\n", 1 && 1);
    printf("1 && 0 (%d)\n", 1 && 0);
    printf("0 && 1 (%d)\n", 0 && 1);
    printf("0 && 0 (%d)\n", 0 && 0);
    printf("1 || 1 (%d)\n", 1 || 1);
    printf("1 || 0 (%d)\n", 1 || 0);
    printf("0 || 1 (%d)\n", 0 || 1);
    printf("0 || 0 (%d)\n", 0 || 0);
    return 0;
}

        最终结果:

       

       练习:

        要求不能使用分支结构

        代码实现:

#include<stdio.h>


int main() {
    int a, b;
    scanf("%d%d", &a, &b);
    //这里需要用到printf函数的返回值
    //printf返回值是输出了多少个字符
    //而这里printf 输出了4个字符 Y E S \n,所以返回值为4
    //那么就可以看为 a < b && 4, 而非0及真所以后半部分为真
    //a < b如果成立就会输出YES
    //不成立就不会输出
    //因为逻辑与如果前面的条件表达式不成立那么,他就不会再去执行后面的代码了
    a < b && printf("YES\n");
    //这里的逻辑和上面相同
    !(a < b) && printf("NO\n");
    return 0;
}

        结果展示:

二.分支结构

if-else 语句

还有一种格式,就是没有{},

#include <stdio.h>

int main() {
    int a, b;
    scanf("%d%d", &a, &b);
    //这种形式只会执行if()后面的一条语句,记住是一条
    if (a < b) printf("YES\n");
    //同理else 也是
    else printf("NO\n");
    return 0;
}

练习:

代码实现:

#include<stdio.h>


int main() {
    int n;
    scanf("%d", &n);
    if (n == 0) {
        printf("HEHE");
    } else if (n > 0 && n < 60) {
        printf("FAIL");
    } else if (n >= 60 && n < 75) {
        printf("MEDIUM");
    } else if (n >= 75 && n <= 100) {
        printf("GOOD");
    }
    printf("\n");
    return 0;
}

最终结果:

switch 语句:

a为一个表达式,

然后如果表达式的值

如果等于v1 执行代码块1,然后依次执行代码块2,代码块3;

如果等于v2, 然后执行代码块2, 代码块3;

如果等于v3, 执行代码块3;

然后如果在case v3下面可能还有一条语句:

default : 代码块4

这条语句的作用就是,如果上面的v1,v2,v3都不等于,就执行代码块4;

对于break的使用在下面代码中来看;

代码演示:
#include<stdio.h>

int main() {
    int a;
    scanf("%d", &a);
    switch (a) {
        //break的作用,如果a = 1,那么就会进入case 1, 执行case 1中的代码段
        //如果没有break,那么执行完case 1中的语句,会接着执行case 2中的语句
        //直到switch 结构末尾才结束
        //那么break的作用就是在相应位置结束switch语句,不在往下执行
        case 1: printf("case a = 1\n"); break;
        case 2: printf("case a = 2\n"); break;
        case 3: printf("case a = 3\n"); break;
        case 4: printf("case a = 4\n"); break;
        default : printf("default value\n"); break;
    }

    return 0;
}

最终效果:

while 语句

while语句执行流程

代码演示:
int main() {
    //读入一个n,输出1-n
    int n;
    scanf("%d", &n);
    //第一种 实现方式
    int i = 0;
    while (i < n) {
        i += 1;//同理代码 i = i + 1;
        printf("i = %d\n", i);
    }
    //第二种
    printf("-----------------\n");//分界线
    i = 1;
    while (i <= n) {
        //i++,这个代码的意思就是,先用i的值,然后在对i进行+1操作
        //就比如现在 i为1,然后输出i = 1, 现在在对i进行+1操作,i就为2了
        printf("i = %d\n", i++); 
    }
    i = 0;
    //第三种
    printf("-----------------\n");//分界线
    while (i < n) {
        //++i,这个代码的意思就是,先对i进行+1操作,然后在用i的值
        //比如现在i为0,先对i进行+1操作,现在i = 1,然后在使用i,也就是输出i = 1;
        printf("i = %d\n", ++i);
    }
    printf("-----------------\n");//分界线
    i = 1;
    //第四种 
    //这种会有一个bug,当n为0的时候应该不会输出,但是他要执行一次
    //这就是 while 和 do_while 的区别
    //do_while 不管表达式成不成立都会先执行一次
    do {
        printf("i = %d\n", i++);
    } while (i <= n);
    return 0;
}

最终结果:

BUG结果:

这里就是do_while语句执行了一次

技巧,如何通过while循环读入

#include<stdio.h>


int main() {
    int x;
    //利用scanf的返回值,scanf的返回值是成功读入了多少个参数
    //而EOF对应整形值是-1,EOF也称文件结束符
    //scanf读到文件末尾时,就会返回-1
    //就会结束循环
    while (scanf("%d", &x) != EOF) {
        printf("2 * x = %d\n", x * 2);
    }
    return 0;
}

最终结果:

如何结束循环读入 ctrl + c

for 语句

循环执行流程:

代码演示:

#include<stdio.h>
int main() {
    //实现打印1-n;
    int n, i;
    scanf("%d", &n);
    for (i = 1; i <= n; i++) {
        printf("%d ", i);
    }
    printf("\n---------------\n");
    //条件可以为空,三个条件都可以为空,但是需要注意避免死循环
    for (i = 1; ; i++) {
        //遇见break 就会跳出循环
        if (i > n) break;
        printf("%d ", i);
    }
    printf("\n---------------\n");
    //只输出单数
    for (i = 1; i <= n; i++) {
        if (i % 2 == 0) continue;
        printf("i = %d\n", i);
    }
    printf("\n");
    return 0;
}

最终结果:

goto语句

goto语句使用代码演示:
#include <stdio.h>

int main() {
    goto lab_1;//执行完后直接跳转到lab_1:
    printf("hello world\n");
lab_1 ://上面的printf不会被执行,直接被跳过,直接执行下面的代码
    printf("hello hangzhou\n");
    goto lab_2;//同理跳转到lab_2:
    int a = 0, b = 0;
    scanf("%d%d", &a, &b);
lab_2 ://这里可以使用变量a,b但是上面的赋值是无效的
    printf("%d\n", a * b);
    return 0;
}

代码执行结果:

可以看到a * b 的结果不是0,而是一个陌生的值,而且也没有利用scanf输入a和b的值

goto 语句模拟if-else 语句
#include <stdio.h>


int main() {
    //判断n是偶数,还是基数
    int n;
    scanf("%d", &n);
    //{}里可以放多条表达式,而小括号的作用就是将大括号里的内容变为具有返回值的表达式
    //而返回值的是多少,就是最后一条表达式的值
    //这里括号里面的返回值是最后表达式的值,那么就是1
    //通过逻辑与的判断,只要前面的语句为真就会执行后面的语句
    //因为后面的语句为1,所以一定为真
    //然后通过goto语句直接跳转,从而模拟了if_else 语句
    n % 2 == 0 && ({ goto if_stmt; 1; });
    !(n % 2) == 0 && ({ goto else_stmt; 1;});

if_stmt:
    printf("%d is even\n", n);
    goto if_end;
else_stmt:
    printf("%d is odd\n", n);
if_end:
    return 0;
}

执行结果:

goto 语句模拟switch 语句
#include <stdio.h>


int main() {
    //输入数字1-3,然后输出对应的英文
    int n;
    scanf("%d", &n);
    //和if—else 语句同样的实现方法
    n == 1 && ({goto lab_1; 1; });
    n == 2 && ({goto lab_2; 1; });
    n == 3 && ({goto lab_3; 1; });
    //error 就相当于default的作用
    goto error;
lab_1:
    printf("One\n");
    //这里为什么要goto end
    //如果没有goto end,就会往下继续执行 lab_2
    //所以需要跳转到结束
    goto end;
lab_2:
    printf("Two\n");
    goto end;
lab_3:
    printf("Tree\n");
    goto end;
error:
    printf("input error\n");
end:
    return 0;
}

执行结果:

goto 语句模拟while 语句

可以回顾一下while语句的执行流程

#include <stdio.h>

int main() {
    //代码要求,输出1-n的值
    int n, i = 1;
    scanf("%d", &n);
judge:
    //这里判断i是否小于等于n, 如果满足那就继续执行
    if (i <= n) goto lab_1;//循环判断条件
    //不满足就跳出循环
    else goto while_end;//这里就是结束循环

lab_1:
    //这里需要i++,不然会死循环一直输出1
    //也可以不用i++,在下面使用i += 1;
    printf("%d ", i++);
    //这个位置使用i += 1;
    goto judge;//这里judge的作用就是返回到判断条件除
while_end:
    printf("\n");
    return 0;
}

最终执行结果:

goto 语句模拟for 语句

可以先回顾上面的for语句执行流程
代码演示:

#include<stdio.h>

int main() {
    //输出1-n
    int n;
    scanf("%d", &n);
    int i;
//初始化
for_1:
    i = 1;
    goto for_2;
for_2:
    if (i <= n) goto for_4;//为真执行代码块
    else goto for_end;//为假循环结束
//执行后操作
for_3:
    i += 1;//或者i++;
    goto for_2; //回到条件判断
//执行代码块
for_4:
    printf("%d ", i);
    goto for_3;
//循环结束
for_end:
    printf("\n");
    return 0;
}

代码执行结果:

C语言中的[一条语句]

 代码解释:

#include<stdio.h>

int main() {
    //1为真所以一定会执行if后面的代码段
    //{}中的代码就是一条语句,也就是复合语句
    if (1) {
        printf("hello\n");
        printf("ni hao\n");
    }
    //while后面控制一条语句也就是if语句
    //然后if后面控制复合语句
    //所以这里if语句会执行55次
    int n = 5;
    while (n--) if(1)  {
        printf("hello\n");
        printf("666\n");
    }
    //循环1后面的语句就是循环1和代码段2组成的复合语句
    //循环1开始后,先执行循环2,循环2开始执行然后执行代码段1
    //循环2结束后,执行代码段20
    //然后又返回到循环1,直到循环1结束
    for (int i = 1; i <= 3; i++) {//循环1
        for (int j = 1; j <= 3; j++) {//循环2
            printf("(%d, %d), ", i, j);//代码段1
        }
        //代码段2
        printf("\n");
    }
    return 0;
}

代码运行结果:

本章小结:

        本章学习了控制流,掌握了对代码执行流程的改变;学习了这么多新的语句,在学习过后一定要实际的去用新学的语句进行写代码,做题,加深对新知识的理解和记忆,以及加快打代码的速度。

        最后加油,看到这里你已经超过百分之95的人了。

        

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1518993.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

1335:【例2-4】连通块

【算法分析】 设数组vis&#xff0c;vis[i][j]表示(i,j)位置已经访问过。遍历地图中的每个位置&#xff0c;尝试从每个位置开始进行搜索。如果该位置不是0且没有访问过&#xff0c;那么访问该位置&#xff0c;并尝试从其上下左右四个位置开始搜索。在看一个新的位置时&#xff…

网络机顶盒什么牌子好?小编盘点零差评网络机顶盒排行榜

在挑选网络机顶盒的时候我们往往会参考销量和口碑&#xff0c;小编花费一个月时间整理了热门网络机顶盒的用户评价情况&#xff0c;整理了这份口碑最好的网络机顶盒排行榜&#xff0c;跟着我一起看看网络机顶盒什么牌子好吧。 NO.1、泰捷WEBOX WE40S网络机顶盒 在混迹网络机顶…

Linux下的多线程编程:原理、工具及应用(1)

&#x1f3ac;慕斯主页&#xff1a;修仙—别有洞天 ♈️今日夜电波&#xff1a;Flower of Life—陽花 0:34━━━━━━️&#x1f49f;──────── 4:46 &#x1f504; ◀️ ⏸ ▶️ ☰ …

浅谈估值模型:从估值-收益分布看待市场投资价值

摘要及声明 1&#xff1a;本文从估值的角度&#xff0c;通过深入研究指数估值变化的特征&#xff0c;总结出市场几轮牛熊背后的规律&#xff0c;从而客观理性地判断目前市场的投资价值。技术方面&#xff0c;本文通过ipywidgets交互式控件实现数据的可视化和交互式展示。 2&a…

Git 学习笔记 三个区域、文件状态、分支、常用命令

Git 学习 GitGit概念VS Code中使用仓库&#xff08;repository&#xff09;示例 Git 使用时的三个区域示例 Git 文件状态示例 Git 暂存区示例 Git 回退版本删除文件忽略文件示例 分支分支的使用分支的合并与删除分支的合并冲突 Git常用命令Git远程仓库 (HTTP)步骤远程仓库 克隆…

游戏开发需不需要考研?

近年来&#xff0c;中国游戏行业增速放缓&#xff0c;用户基数趋于饱和&#xff0c;行业监管日趋严格&#xff0c;国外竞争激烈&#xff0c;使游戏公司面临挑战。为适应形势&#xff0c;游戏企业正在调整策略&#xff0c;采取主动学习和实战练习的方式&#xff0c;提升游戏质量…

虚拟环境的激活

(此博客仅用于我记录虚拟环境的激活方法) 虚拟环境的激活命令: venv/Scripts/activate 在F:\git repo\Database-Course-Design 这个文件夹中启动命令行 这个文件夹中含有虚拟环境venv 输入命令venv/Scripts/activate&#xff0c;就得到下面的结果: 此时就激活了虚拟环境&…

AVCE - AV Evasion Craft Online 更新 8 种加载方式 - 过 WD 等

免责声明&#xff1a;本工具仅供安全研究和教学目的使用&#xff0c;用户须自行承担因使用该工具而引起的一切法律及相关责任。作者概不对任何法律责任承担责任&#xff0c;且保留随时中止、修改或终止本工具的权利。使用者应当遵循当地法律法规&#xff0c;并理解并同意本声明…

3. ElasticSearch搜索技术深入与聚合查询实战

1. ES分词器详解 1.1 基本概念 分词器官方称之为文本分析器&#xff0c;顾名思义&#xff0c;是对文本进行分析处理的一种手段&#xff0c;基本处理逻辑为按照预先制定的分词规则&#xff0c;把原始文档分割成若干更小粒度的词项&#xff0c;粒度大小取决于分词器规则。 1.2 …

[SWPUCTF 2021 新生赛]crypto6

题目&#xff1a; 从代码可以看出​​​​​​该题目对flag依次进行了base64,base32,base16加密。要得到正确的flag即进行相反的操作&#xff0c;即依次进行base16,32,64的解码即可

dp求公共子序列

#include<iostream> using namespace std; int main(){string a1,a2;while(cin>>a1>>a2){int data[201][201]{};// 每次的最长记录for(int i1;i<a1.size();i){for(int j1;j<a2.size();j){if(a1[i-1] a2[j-1]){// 相等在2个字母未加进之前长度1data[i]…

MOS管、IGBT的区别

MOS管&#xff0c;即Metal-Oxide-Semiconductor Field-Effect Transistor&#xff0c;是我们常见的一种半导体器件&#xff0c;也被广泛称为MOSFET。 这种器件的工作原理独特且高效&#xff0c;主要是通过控制栅极电压来调控电流在两个源极和漏极之间的流动&#xff0c;这也是其…

使用LLMs大模型进行股票投资预测——能实现盈利还能自我反思并给出合理解释

前言 股市的变化难以预测&#xff0c;任何微小的变化都可能对股票走势产生影响&#xff0c;这种不确定性让投资者们感到困惑。因此&#xff0c;研究者们开始关注目前备受关注的大型模型技术&#xff0c;他们试图利用这些技术来高效地处理和分析大量的股市数据&#xff0c;从中…

c++基础语法—————默认成员函数

文章目录 一、构造函数&#xff08;初始化&#xff09;1.构造函数的名称与类名相同&#xff0c;没有返回类型&#xff0c;可以有参数。2.对象实例化时&#xff0c;编译器自动调用构造函数进行初始化3.若类中没有显示定义一个用户的构造函数&#xff0c;编译器则会自动生成一个默…

[LVGL]:MACOS下使用LVGL模拟器

如何在MACOS下使用lvgl模拟器 1.安装必要环境 brew install sdl2查看sdl2安装位置&#xff1a; (base) ➜ ~ brew list sdl2 /opt/homebrew/Cellar/sdl2/2.30.1/bin/sdl2-config /opt/homebrew/Cellar/sdl2/2.30.1/include/SDL2/ (78 files) /opt/homebrew/Cellar/sdl2/2.3…

计算机系统·浮点数

浮点数 理解含有小数值的二进制数 定点表示方法 十进制&#xff1a;以小数点为分界线&#xff0c;小数点左边数字的权重是10的正幂&#xff0c;小数点右边数字的权重是10的负幂。如图所示 二进制&#xff1a;小数点左边数字的权重是2的正幂&#xff0c;小数点右边数字的权重…

免费阅读篇 | 芒果YOLOv8改进111:注意力机制CBAM:轻量级卷积块注意力模块,无缝集成到任何CNN架构中,开销可以忽略不计

&#x1f4a1;&#x1f680;&#x1f680;&#x1f680;本博客 改进源代码改进 适用于 YOLOv8 按步骤操作运行改进后的代码即可 该专栏完整目录链接&#xff1a; 芒果YOLOv8深度改进教程 该篇博客为免费阅读内容&#xff0c;YOLOv8CBAM改进内容&#x1f680;&#x1f680;&am…

Exam in MAC [容斥]

题意 思路 正难则反 反过来需要考虑的是&#xff1a; (1) 所有满条件一的(x,y)有多少对&#xff1a; x 0 时&#xff0c;有c1对 x 1 时&#xff0c;有c对 ...... x c 时&#xff0c;有1对 以此类推 一共有 (c2)(c1)/2 对 (2) 符合 x y ∈ S的有多少对&#xff1a…

深度学习每周学习总结P1(pytorch手写数字识别)

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 | 接辅导、项目定制 目录 0. 总结1. 数据导入部分2. 模型构建部分3. 训练前的准备4. 定义训练函数5. 定义测试函数6. 训练过程 0. 总结 总结: 数据导入部分&a…

Jmeter进行http接口测试

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 关注公众号【互联网杂货铺】&#xff0c;回复 1 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 本文主要针对http接口进行测试&#xff0c;使用 jmeter工具实现…