嵌入式课程day07-C语言流程控制语句

目录

五、流程控制语句

5.4跳转结构

5.4.1break

5.4.2continue

5.4.3goto

5.4.4return

5.5额外拓展

5.5.1死循环的写法

5.5.2循环嵌套

5.5.3随机数函数

五、流程控制语句

5.4跳转结构

break、continue、goto、return

5.4.1break

结束替它最近的循环

例子:输出所有三位数中能被17整除的最大数

cs 复制代码
#include<stdio.h>
int main()
{
    int a = 999;
	for(a;a>=100;a--)
		if(a%17==0)
		{
			printf("%d",a);
			break;
		} 
    return 0;
}

5.4.2continue

结束本次循环,循环还在继续。在循环体里面,如果执行了continue,他下面的语句不再执行。

cs 复制代码
#include<stdio.h>
int main()
{
	//输出1~10所有3的倍数 
    int i;
    for(i=1;i<=10;i++)
    {
    	if(i % 3 != 0)
    		continue;
    	printf("%d ",i);
	}

    // 3 6 9 
    return 0;
}

5.4.3goto

无条件跳转。1、设置跳转的位置,标识符(大写):2、写跳转语句,goto 标识符名。

cs 复制代码
#include<stdio.h>
int main()
{
	//输出1~10所有3的倍数 
    int i = 0;
    L://标识符
    printf("%d ",i);
    i++;
    if(i<5)
    goto L;
    //0 1 2 3 4
    return 0;
}

注意事项:标识符的位置和goto必须在同一个函数内部

5.4.4return

结束函数,return 0;(0代表程序正常结束)另有其他值。

5.5额外拓展

5.5.1死循环的写法

cs 复制代码
for(;;);
while(1);

5.5.2循环嵌套

输出下面的数据

A

A B

A B C

.....

cs 复制代码
#include<stdio.h>
int main()
{
    int i,j,k;
    char a;
    scanf("%d",&j);
    for(i=1;i<=j;i++)
    {
    	for(a='A';a-'A'<i;a++)
    		printf("%c ",a);
    	printf("\n");
	}
    return 0;
}

输出下面的数据

A

A B A

A B C B A

.....

cs 复制代码
#include<stdio.h>
int main()
{
    int i,j,k;
    char a;
    scanf("%d",&j);
    for(i=1;i<=j;i++)
    {
    	for(a='A';a-'A'<i-1;a++)
    		printf("%c ",a);
    	for(a;a-'A'>=0;a--)
    		printf("%c ",a);
    	printf("\n");
	}
    return 0;
}

输出下面的数据

A

A B A

A B C B A

cs 复制代码
#include<stdio.h>
int main()
{
    int i,j,k;
    char a;
    scanf("%d",&j);
    for(i=1;i<=j;i++)
    {
		k=i;
		while(j-k){
			k++;
			printf("  ");
		}
    	for(a='A';a-'A'<i-1;a++){
    		printf(" %c",a);    		
		}

    	for(a;a-'A'>=0;a--)
    		printf(" %c",a);
    	printf("\n");
	}
    return 0;
}

5.5.3随机数函数

在C语言中,生成随机数通常涉及到两个函数:rand()srand() 。这两个函数都定义在 <stdlib.h> 头文件中。

rand() 函数

cs 复制代码
#include <stdio.h>
#include <stdlib.h>

int main() {
    int a = rand();
    printf("%d\n", a);
    // 输出不确定
    return 0;
}
相关推荐
荒古前24 分钟前
龟兔赛跑 PTA
c语言·算法
Colinnian27 分钟前
Codeforces Round 994 (Div. 2)-D题
算法·动态规划
用户00993831430133 分钟前
代码随想录算法训练营第十三天 | 二叉树part01
数据结构·算法
shinelord明37 分钟前
【再谈设计模式】享元模式~对象共享的优化妙手
开发语言·数据结构·算法·设计模式·软件工程
დ旧言~43 分钟前
专题八:背包问题
算法·leetcode·动态规划·推荐算法
嵌入式科普1 小时前
十三、从0开始卷出一个新项目之瑞萨RZN2L串口DMA接收不定长
c语言·stm32·瑞萨·e2studio·rzn2l
_WndProc1 小时前
C++ 日志输出
开发语言·c++·算法
薄荷故人_1 小时前
从零开始的C++之旅——红黑树及其实现
数据结构·c++
努力学习编程的伍大侠1 小时前
基础排序算法
数据结构·c++·算法