常用的流程图符号

  • 起止框用于表示流程的开始或结束;
  • 输入/输出框用平行四边形表示,在平行四边形内可以写明输入或输出的内容;
  • 判断框用菱形表示,它的作用是对条件进行判断,根据条件是否成立来决定如何执行后续的操作;
  • 处理框用矩形表示,它代表程序中的处理功能,如算术运算和赋值等;
  • 流程线用实心单向箭头或直线表示,可以连接不同位置的图框,流程线的标准流向是从左到右和从上到下,可用直线表示,非标准流向的流程线应使用箭头指示方向;
  • 连接点用圆形表示,用于流程图的延续。

在C语言中0代表假,非0代表真

顺序结构语句

最常见的执行结构,计算机语言往大了说都是属于顺序结构

顺序结构:所有语句从上到下顺序执行

选择结构语句

if条件语句

  • if语句
if (条件语句)
{
//代码块
}

  • if···else语句
if (判断条件)
{
//执行语句1
···
}
else
{
//执行语句2
···
}

  • if···else if···else语句

    else永远是和最近的一条if语句配对
if (判断条件1)
{
//执行语句1
}
else if (判断条件2)
{
//执行语句2
}
···
else if (判断条件n)
{
//执行语句n
}
else
{
//执行语句n+1
}

switch条件语句

switch作为一种条件选择语句,主要适用于具体值的判断,而if适用于范围值的判断,侧重点不同。

switch是为多重选择准备的,遇到break语句,switch就终端执行

switch (表达式)
{
case 目标值1:
//执行语句1
break;
case 目标值2:
//执行语句2
break;
···
case 目标值n:
//执行语句n
break;
default:
//执行语句n+1
break;
}

switch将表达式的值与case中的值对比,执行与之相匹配的case内语句,直到遇到break退出。

循环结构语句

在符合某一条件的情况下,不断地重复某一段代码,这种叫做循环语句

while循环语句

while (循环条件)
{
//执行语句
···
}

do-while循环语句

do
{
//执行语句
···
} while(循环条件);

for循环语句

for(初始化表达式; 循环条件; 操作表达式)
{
//执行语句
···
}

循环嵌套

循环嵌套在各种语言中都很常用

外层循环控制行,内层循环控制列

*
**
***
****
*****
******
*****
****
***
**
*
int i;
int j;
for (i = 0; i < 11; i++)
{
if (i < 6)
{
for (j = 0; j <= i; j++)
{
printf("*");
}
}
else
{
for (j = 11 - i; j > 0; j--)
{
printf("*");
}
}
printf("\n");
}
    *
***
*****
*******
*********
int i;
int j;
for (i = 0; i < 5; i++)
{
for (j = 4 - i; j > 0; j--)
{
printf(" ");
}
for (j = 0; j < (i - 1) * 2 + 3; j++)
printf("*");
printf("\n");
}

跳转语句(break、goto、continue)

  • break语句

    在switch条件语句和循环语句中都可以使用break语句

    当它出现在switch条件语句中时,作用是终止某个case并跳出switch结构

    当它出现在循环语句中,作用是跳出当前循环语句,执行后面的代码

  • goto语句

    尽量不要在程序当中使用goto语句

    当break语句出现在嵌套循环中的内层循环时,它只能跳出内层循环,如果想要跳出外层循环则需要对外层循环添加标记,然后使用goto语句

    int i = 0;
start:
scanf("%d", &i);
if(i == 1)
goto start;
  • continue语句

    在循环语句中,如果希望立即终止本次循环,并执行下一次循环,此时就需要使用continue语句

C学习笔记-流程控制的更多相关文章

  1. JavaScript学习笔记——流程控制

    javascript流程控制流程:就是程序代码的执行顺序.流程控制:通过规定的语句让程序代码有条件的按照一定的方式执行. 一.顺序结构 按照书写顺序来执行,是程序中最基本的流程结构. 二.选择结构(分 ...

  2. Go语言学习笔记-流程控制(二)

    Go语言流程控制 字典类型Map 1.上节遗留:map字典类型 变量声明:var myMap map[string] PersonInfo 其中,myMap是变量名,string是键的类型,Perso ...

  3. go学习笔记-流程控制(if/else,for/range)

    流程控制(if/else,for/range) if if条件判断语句的语法概括起来就是:如果满足条件就做某事,否则做另一件事. func testIf() { num := 10 if num &l ...

  4. python学习笔记---流程控制

    二.流程控制 2.1选择结构与语句 2.1.1 最简单的if语句 注意:if语句后边必须加上冒号 满足条件后.可以执行多条语句. #最简单的if语句 print("请输入一个既能整除2,又能 ...

  5. Java学习笔记-流程控制

    在Java中,最常见的就是顺序结构,另外,还有其他的一些的结构,选择,循环等,这些程序结构的加入,使得程序代码更有选择性 判断结构 if语句 三种格式: if(条件表达式) { 执行语句; } if( ...

  6. TCP/IP学习笔记17--TCP-- 窗口控制 重发控制 流控制

    事业无穷年 -- 韩愈 利用窗口控制提高速度: TCP传输数据是,以一个段为单位(每次发送一个数据包),每发一个段需要一次确认应答,这样就难免存在这样的缺点:包的往返时间越长,通信性能就越低. 为解决 ...

  7. luogg_java学习_03_流程控制及循环结构

    本文为博主辛苦总结,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用. 转载请注明 出自 : luogg的博客园 谢谢配合! 程序流程控制 顺序结构 分支结构:if-else,sw ...

  8. Python学习(七) 流程控制if语句

    在Python中流程控制if语句采用如下格式: if expression : statement elif expression : statement elif expression : stat ...

  9. python学习Day4 流程控制(if分支,while循环,for循环)

    复习 1.变量名命名规范 -- 1.只能由数字.字母 及 _ 组成 -- 2.不能以数字开头 -- 3.不能与系统关键字重名 -- 4._开头有特殊含义 -- 5.__开头__结尾的变量,魔法变量 - ...

随机推荐

  1. vue 后退不刷新,前进刷新 keep-alive

    最近在开发中遇到了这样的一个问题: A.B.C三个页面,有如下这样的场景: (1)从页面A离开进入B或C的时候,缓存A页面的数据,并且返回到A后,能保持A页面的跳转前职位 (2)离开B进入C的时候,缓 ...

  2. qt 防止应用重复启动

    QApplication a(argc, argv); QSharedMemory singleton(a.applicationName()); if(!singleton.create(1)) { ...

  3. MultipartFile类

    MultipartFile类常用的一些方法: String getContentType()//获取文件MIME类型InputStream getInputStream()//后去文件流String ...

  4. C++Error2208:...尝试引用已删除的函数

    C++Error2208:…尝试引用已删除的函数在使用自己编写的类实例化c++stl容器vector时,调用了vector.erase()方法,结果编译器报了以下错误 错误 C2280 “(类名):: ...

  5. 并发编程入门(一): POSIX 使用互斥量和条件变量实现生产者/消费者问题

    boost的mutex,condition_variable非常好用.但是在Linux上,boost实际上做的是对pthread_mutex_t和pthread_cond_t的一系列的封装.因此通过对 ...

  6. 基础 Linux 命令速查清单

    jaywcjlove/linux-command: Linux命令大全搜索工具,内容包含Linux命令手册.详解.学习.搜集.https://git.io/linux  https://github. ...

  7. Codeforces 1246D/1225F Tree Factory (构造)

    题目链接 https://codeforces.com/contest/1246/problem/D 题解 首先考虑答案的下界是\(n-1-dep\) (\(dep\)为树的深度,即任何点到根的最大边 ...

  8. CodeForces Good Bye 2016

    A题,水题略过. B题,也水,但是想复杂了.只要运动超出[0,20000]的范围就算不可能了. C题,我自己的方法是解不等式,然后取最大的答案即可.代码如下: #include <stdio.h ...

  9. 锁对象Lock-同步问题更完美的处理方式

    Lock是java.util.concurrent.locks包下的接口,Lock 实现提供了比使用synchronized 方法和语句可获得的更广泛的锁定操作,它能以更优雅的方式处理线程同步问题,我 ...

  10. 7. 使用Hystrix实现微服务的容错处理

                  使用Hystrix实现微服务的容错处理 7.1. 实现容错的手段 7.1.1. 雪崩效应 在微服务架构中通常会有多个服务层调用,基础服务的故障可能会导致级联故障,进而造成整 ...