嵌入式课程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;
}
相关推荐
吃着火锅x唱着歌1 分钟前
LeetCode 1128.等价多米诺骨牌对的数量
算法·leetcode·职场和发展
ᐇ95928 分钟前
Java HashMap深度解析:数据结构、原理与实战指南
java·开发语言·数据结构
十八岁讨厌编程29 分钟前
【算法训练营 · 补充】LeetCode Hot100(中)
算法·leetcode
橘颂TA31 分钟前
【剑斩OFFER】算法的暴力美学——最小覆盖字串
算法·c/c++·就业
wearegogog12333 分钟前
基于混合蛙跳算法和漏桶算法的无线传感器网络拥塞控制与分簇新方法
网络·算法
Tiandaren2 小时前
大模型应用03 || 函数调用 Function Calling || 概念、思想、流程
人工智能·算法·microsoft·数据分析
2301_795167202 小时前
玩转Rust高级应用 如何进行理解Refutability(可反驳性): 模式是否会匹配失效
开发语言·算法·rust
云知谷2 小时前
【C/C++基本功】C/C++江湖风云录:void* 的江湖传说
c语言·开发语言·c++·软件工程·团队开发
小当家.1052 小时前
[LeetCode]Hot100系列.贪心总结+思想总结
算法·leetcode·职场和发展
墨雪不会编程3 小时前
数据结构—排序算法篇二
数据结构·算法·排序算法