C语言循环结构详解

目录
  • break语句
  • continue语句
  • C语言循环结构
    • 一、goto 语句(现在一般很少用)
      • 1.语句介绍:
      • 2.语法结构:
      • 3.goto 语句程序示例:
    • 二、do-while语句
      • 1.语句介绍:
      • 2.语法结构:
      • 3.do-while 流程图:
      • 4.do-while 语句程序示例:
    • 三、while 语句
      • 1.语句介绍:
      • 2.语法结构:
      • 3.while 循环流程图:
      • 4.while 语句程序示例:
    • 四、for 循环语句:
      • 1.语句介绍:
      • 2.语法结构:
      • 3.for 循环语句流程图
      • 4.for 循环程序示例:
      • 5.for 循环语句使用时注意事项:
  • 总结

Hello,everyone!forever 之前介绍了C分支结构,今天按照顺序该来介绍C语言循环结构啦!希望能给大家带来一点点帮助吧!
首先来了解一下循环吧!循环是用于重复执行某一个条件语句的语句,其中控制表达式为其核心,整个循环围绕这个控制表达式进行展开,如果表达式为真,循环继续执行;否则,循环结束。C语言中循环语句一般有 do-while 语句、while 语句和 for 语句,还有一个 goto 语句。

在介绍循环前,我先来给大家说说循环中常用的 break 和 continue 吧!

break语句

break 语句用于 switch 分支语句(之前文章有介绍)和各种循环语句。在 switch 语句中 break 代表终止的意思,遇到 break 则意味着终止当前的 switch 语句;在循环语句中,break 作用是跳出当前循环。

continue语句

continue 语句只用在循环语句中。在循环体语句执行中,continue 用于结束本次循环不再执行循环后面的程序,直接进行下一次循环。它一般总是有条件判断执行的。

C语言循环结构

一、goto 语句(现在一般很少用)

1.语句介绍:

C语言中提供了可以随意滥用的 goto 语句和标记跳转的符号。一般在实践中没有 goto 语句也可以很容易的实现代码的书写,但是在某种场合下还是可以用到的,最常用的是终止程序在某些深度嵌套的结构中的所用方法,比如利用它一次跳出多层循环。(一般这种情况,break达不到目的,就利用 goto 语句实现)

2.语法结构:

以下就是 goto 语句的语法结构,其中包含标记跳转符号和 goto 语句 ;代码从上往下运行,遇到 goto ko 就会跳转到 ko ,这就是 goto 语句,起到直接跳转的作用。

int main()
{
ko:
 	goto ko;
     return 0;
}

3.goto 语句程序示例:

电脑关机指令程序:该程序利用到 goto 语句来跳转,以达到指令输入正确。

#include<stdio.h>
#include<stdlib.h>//system函数调用头文件
#include<string.h>//strcmp函数调用头文件
int main()
{
	char arr[] = { 0 };
	system("shutdown -s -t 60");//电脑关机命令
ko:
	printf("您的电脑即将关机,请输入:“停止操作”,将终止电脑关机\n");
	scanf("%s", arr);
	if (strcmp(arr, "停止操作"))//判断输入的指令
	{
		system("shutdown -a");//取消电脑关机命令
	}
	else
	{
		goto ko;//goto 跳转语句
	}
	return 0;
}

二、do-while语句

1.语句介绍:

do-while 循环语句其特点是先执行再判断,首先无条件执行一次循环体,然后再根据控制表达式来判断,若判断为真,则继续执行循环;否则循环结束。所以 do-while 语句至少要执行一次循环。

2.语法结构:

以下是 do-while 循环语句的语法结构,先执行再循环,至少执行循环一次。

int main()
{
	do
	{
		循环语句;
	} while (表达式);//这里的分号一定不能少,注意咯!
	return 0;
}

3.do-while 流程图:

4.do-while 语句程序示例:

简单的猜数字游戏程序

#include<stdio.h>
int main()
{
	int n = 0;
	int a = 8;
	do
	{
		printf("请输入0-10猜数字\n");
		scanf("%d", &n);
	} while (n != a);
	printf("猜对了!\n");
	return 0;
}

三、while 语句

1.语句介绍:

while 语句是先判断再执行。首先判断控制表达式,若为真则继续向下执行;若为假则循环结束。

2.语法结构:

若循环体中的循环语句只有一条时,可以不用括号{ }括起来;若循环语句为多条时,必须用括号{ }括起来。

int main()
{
	while (表达式)
	{
		循环语句;
	}
	return 0;
}

3.while 循环流程图:

4.while 语句程序示例:

辗转相除法求最小公倍数和最大公约数

#include<stdio.h>
int main()//辗转相除法求最小公倍数和最大公约数
{
	int m = 12, n = 16;//m 和 n 为待求数
	int x = 0, y = 0;
	int z = 0;
	x = m, y = n;
	while (m != 0)//while 循环
	{
		z = n % m;
		n = m;
		m = z;
	}
	printf("最小公倍数:%d\n最大公约数:%d", n, x * y / n);
	return 0;
}

四、for 循环语句:

1.语句介绍:

for 循环是C语言中最常用的循环语句,其格式为: for (表达式1;表达式2;表达式3)。其中表达式1为循环变量初赋值,表达式2为循环条件,表达式3为循环变量增量。首先给变量赋值,接下来进行变量判断:若判断为真,则继续循环;否则循环停止,最后进行变量增减量改变。

2.语法结构:

其写法和 while语句 差不多,若后面循环体里有多条语句,则用括号括起来,形成代码块。

int main()
{
	for (表达式1; 表达式2; 表达式3)
	{
		循环语句;
	}
	return 0;
}

3.for 循环语句流程图

4.for 循环程序示例:

输出1-10的奇数程序

#include<stdio.h>
int main()
{
	int i = 1;
	for (i = 1; i <= 10; i++)
	{
		if (i % 2 == 0)
		{
			continue;//这里含有 continue ,结束本次循环,不输出偶数
		}
		printf("%d\n", i);
	}
	return 0;
}

5.for 循环语句使用时注意事项:

(1)for 循环中表达式1、2、3是选择项,可以缺省,但中间的分号不能掉;

(2)若省略表达式2,则无判断条件,会出现死循环;

(3)表达式1和3中可以进行多个变量初赋值和多个变量增量。

目前就这些!这些代码都比较简单,浅显易懂,希望对一些初学者有一定帮助,也望其他大佬能多多指点!如有不足或错误之处,请谅解并指教哈!

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注我们的更多内容!

时间: 2021-10-11

C语言数据结构之循环链表的简单实例

 C语言数据结构之循环链表的简单实例 实例代码: # include <stdio.h> # include <stdlib.h> typedef struct node //定义链表中结点的结构 { int code; struct node *next; }NODE,*LinkList; /*错误信息输出函数*/ void Error(char *message) { fprintf(stderr,"Error:%s/n",message); exit(1)

详解数据结构C语言实现之循环队列

本文讲的是循环队列,首先我们必须明白下面几个问题 循环队列的基础知识 1.循环队列需要几个参数来确定 循环队列需要2个参数,front和rear 2.循环队列各个参数的含义 (1)队列初始化时,front和rear值都为零: (2)当队列不为空时,front指向队列的第一个元素,rear指向队列最后一个元素的下一个位置: (3)当队列为空时,front与rear的值相等,但不一定为零: 3.循环队列入队的伪算法 (1)把值存在rear所在的位置: (2)rear=(rear+1)%maxsize

C语言数据结构之双向循环链表的实例

数据结构之双向循环链表 实例代码: #include <stdlib.h> #include <stdio.h> #include <malloc.h> typedef struct Node{ struct Node *pNext; int data; struct Node *prior; } NODE,*PNODE; PNODE CreatList(); void TreNode(PNODE pHead); bool isEmpty(PNODE pHead); i

C语言数据结构之判断循环链表空与满

C语言数据结构之判断循环链表空与满 前言: 何时队列为空?何时为满? 由于入队时尾指针向前追赶头指针,出队时头指针向前追赶尾指针,故队空和队满时头尾指针均相等.因此,我们无法通过front=rear来判断队列"空"还是"满". 注:先进入的为'头',后进入的为'尾'. 解决此问题的方法至少有三种: 其一是另设一个布尔变量以匹别队列的空和满: 其二是少用一个元素的空间,约定入队前,测试尾指针在循环意义下加1后是否等于头指针,若相等则认为队满(注意:rear所指的单元始

C语言中对于循环结构优化的一些入门级方法简介

一.代码移动 将在循环里面多次计算,但是结果不会改变的计算,移到循环外面去. 例子: 优化前: void lower1(char *s){ int i; for(i=0;i<strlen(s);++i) if(s[i]>='A'&&s[i]<='Z') s[i]-=('A'-'a'); } 优化后: void lower2(char *s){ int i; int len=strlen(s); for(int i=0;i<len;++i) if(s[i]>='

数据结构 C语言实现循环单链表的实例

数据结构 C语言实现循环单链表的实例 实例代码: //=========杨鑫========================// //循环单链表的实现 #include <stdio.h> #include <stdlib.h> typedef int ElemType; //定义结点类型 typedef struct Node { ElemType data; struct Node *next; }Node,*LinkedList; int count = 0; //1.单循环

Java实现单链表翻转实例代码

Java实现单链表反转,递归和非递归两种形式 /** * 反转单链表 */ /** * 定义链表 * * @author 16026 * */ class Node { int val; Node next; public Node(int val) { this.val = val; } } public class ReverseList { /** * 反转链表 * * @param head * @return */ public static Node reverseList(Node

C++ 实现静态单链表的实例

C++ 实现静态单链表的实例 利用数组实现的静态单链表,与严蔚敏书实现略有不同,不另设回收空间.有任何BUG或错误,希望各位朋友多多反馈~~感激不尽 /* Author : Moyiii * Mail: lc09@vip.qq.com * 静态链表实现,仅作学习之用,当然如果 * 你想拿去用,随你好啦. */ #include <iostream> using namespace std; #define MAX_LIST_SIZE 100 class Node { public: int d

C#数据结构之单链表(LinkList)实例详解

本文实例讲述了C#数据结构之单链表(LinkList)实现方法.分享给大家供大家参考,具体如下: 这里我们来看下"单链表(LinkList)".在上一篇<C#数据结构之顺序表(SeqList)实例详解>的最后,我们指出了:顺序表要求开辟一组连续的内存空间,而且插入/删除元素时,为了保证元素的顺序性,必须对后面的元素进行移动.如果你的应用中需要频繁对元素进行插入/删除,那么开销会很大. 而链表结构正好相反,先来看下结构: 每个元素至少具有二个属性:data和next.data

php实现单链表的实例代码

复制代码 代码如下: <?php //链表节点 class node {     public $id; //节点id     public $name; //节点名称     public $next; //下一节点 public function __construct($id, $name) {         $this->id = $id;         $this->name = $name;         $this->next = null;     } } /

C语言单链表实现方法详解

本文实例讲述了C语言单链表实现方法.分享给大家供大家参考,具体如下: slist.h #ifndef __SLIST_H__ #define __SLIST_H__ #include<cstdio> #include<malloc.h> #include<assert.h> typedef int ElemType; typedef struct Node { //定义单链表中的结点信息 ElemType data; //结点的数据域 struct Node *next

Python数据结构与算法之链表定义与用法实例详解【单链表、循环链表】

本文实例讲述了Python数据结构与算法之链表定义与用法.分享给大家供大家参考,具体如下: 本文将为大家讲解: (1)从链表节点的定义开始,以类的方式,面向对象的思想进行链表的设计 (2)链表类插入和删除等成员函数实现时需要考虑的边界条件, prepend(头部插入).pop(头部删除).append(尾部插入).pop_last(尾部删除) 2.1 插入: 空链表 链表长度为1 插入到末尾 2.2 删除 空链表 链表长度为1 删除末尾元素 (3)从单链表到单链表的一众变体: 带尾节点的单链表

java单链表逆序用法代码示例

本篇博客,比较简单.对单链表逆序不理解的看看就可以了. 逆序思想 现假设有一链表,有待逆序操作.我们首先想到的就是将那个指针关系逆序了就行了呗. 事实上,就是这样.博主就是以这个为目标来完成的单链表逆序操作. Node pre = null; Node post = null; while(head!=null){ post = head.next; head.next = pre; pre = head; head = post; } 这便是逆序的核心了.下面我们就来一步步的讲解. 首次逆序:

C语言创建和操作单链表数据结构的实例教程

1,为什么要用到链表 数组作为存放同类数据的集合,给我们在程序设计时带来很多的方便,增加了灵活性.但数组也同样存在一些弊病.如数组的大小在定义时要事先规定,不能在程序中进行调整,这样一来,在程序设计中针对不同问题有时需要3 0个大小的数组,有时需要5 0个数组的大小,难于统一.我们只能够根据可能的最大需求来定义数组,常常会造成一定存储空间的浪费. 我们希望构造动态的数组,随时可以调整数组的大小,以满足不同问题的需要.链表就是我们需要的动态数组.它是在程序的执行过程中根据需要有数据存储就向系统要求

C语言单链表实现多项式相加

本文实例为大家分享了C语言单链表实现多项式相加的具体代码,供大家参考,具体内容如下 //多项式的相加和相乘 #include<stdio.h> #include<stdlib.h> #pragma warning(disable:4996)//兼容scanf typedef struct node { int coef; int expon; struct node* link; }Polynode,*Polynomial; Polynomial InsertPolyLinklis