嵌入式课程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;
}
相关推荐
Echo_NGC22373 分钟前
【神经视频编解码NVC】传统神经视频编解码完全指南:从零读懂 AI 视频压缩的基石
人工智能·深度学习·算法·机器学习·视频编解码
会员果汁6 分钟前
leetcode-动态规划-买卖股票
算法·leetcode·动态规划
橘颂TA33 分钟前
【剑斩OFFER】算法的暴力美学——二进制求和
算法·leetcode·哈希算法·散列表·结构与算法
地平线开发者2 小时前
征程 6 | cgroup sample
算法·自动驾驶
姓蔡小朋友3 小时前
算法-滑动窗口
算法
君义_noip3 小时前
信息学奥赛一本通 2134:【25CSPS提高组】道路修复 | 洛谷 P14362 [CSP-S 2025] 道路修复
c++·算法·图论·信息学奥赛·csp-s
kaikaile19953 小时前
基于拥挤距离的多目标粒子群优化算法(MO-PSO-CD)详解
数据结构·算法
不忘不弃3 小时前
求两组数的平均值
数据结构·算法
leaves falling3 小时前
迭代实现 斐波那契数列
数据结构·算法