栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

关于c语言循环,我想说的是:

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

关于c语言循环,我想说的是:

大一萌新写的c语言都能看懂版(一)_Why_does_it_work的博客-CSDN博客

大一萌新写的c语言都能看懂版(二)_Why_does_it_work的博客-CSDN博客

编了这么久的代码,对于运行你了解多少?_Why_does_it_work的博客-CSDN博客


循环一直是贯穿整个c语言的主干骨,我们一起返回来再看循环。

while循环要当成当循环,第一篇就强调过,一直理解成当就好了,do,while循环也一样就是先做一步然后当怎么样再返回来

for循环在循环里面用到的是最多的吧

for的初始化

for的初始化就是在第一步,若是循环嵌套的初始化是什么样子的,在第一篇文章中说到,对于循环嵌套需要注意的是首先分清父子循环,就是父亲循环一步,子循环要全部完成,进行下一步父循环,在循环嵌套看代码的时候容易出现的问题的是忽略子循环的初始化

拿第一篇文章中的代码来解释

#include
int main()
{

for(int i = 0; i< 5; i++) {
    for(int j = 0; j <= i; j++) {
        printf("*");
    }
    printf("n");
}return 0;
}

在这个循环当中首先  i=0,j进行一次循环初始化0之后就结束,输入回车键n时进入下一个循环

                                  i=1,j进行第一次循环初始化0之后循环还没有结束,因为1<=1f符合条件进行第二次循环结束

以此类推,总之第一步初始化,第二部判断条件,第三步进入循环,第四步递增或递减,第五步判断,第六步是否继续循环或者结束循环,所以每一次循环的开始都需要初始化,但是一个循环的完全结束,那么就要重新开始

for的循环

对于for循环,我们用的地方有很多,上面已经清晰的了解到for真正的样子,对于for循环我们要思考一下其实每个程序都是一步一步进行的,我们在面对一个个问题的时候都应该想一下他在做什么?这些操作的循环部分是什么?是重复加?重复乘除?还是重复输入?

所以先应该先建立循环体(从大范围思考再思考小范围)在for循环中,for最大的特点是范围确定循环次数已知道

就比如说5+55我就要那循环做,循环了几次,一次呗,所以条件只能进行一步操作

#include 
int main()

{
	int a = 5;
	int s = a;
	for (int i = 1; i <= 1; i++) {
		a = a * 10 + 5;
		s = a + s;
	}
	printf("%d", s);
	return 0;
}

如果算一个前一百以内的和,那就是循环了一百次进行的操作就是每两项之间的关系怎么进入下一项,然后s=a+s

其实这些都是最简单的内容,进阶一下就是循环嵌套,这个在第一篇文章有我就不细说了;

数组

数组也离不开循环,因为数组很烦,数组在之前每一篇文章都有吧,说白了就是a[],二维就是a[][](几行几列),说了很多有关于数组的内容了,说白了就是a是一个指针指向第一个内存空间开始算起一共有几个下标就是几,具体一下?

a[10]从a指向的第一个空间a[0]开始一共有十个空间(其实指针一直忽悠人的就是a[10]和a[0]和i)

在数组的循环当中,数组做的工作是反复开辟空间,所以说他的操作for循环里不是指的数,for循环里是指空间有多少,拿代码看一下

在第一篇文章里就是这个代码,可以回去看一下

#include 
 
int main() {
	int i, a[10];
	for (i = 0; i <= 9; i++)
		a[i] = i;
	for (i = 9; i >= 0; i--)
		printf("%d", a[i]);
	return 0;
}

这个代码中,首先定义了一个数组构造类型的变量,所以说这个全局变量是指这个程序中就开辟了这么大的空间,我们先对于数组进行开辟我们想使用的空间,就有第一个循环,因为我们在第一篇很是强调,第一个空间是从0开始,所以我们for循环初始化的数字就是0;一共要用到十个空间所以<10就可以了那么我们对于每一个空间进行赋值操作,就有每一步的赋值操作,十次循环结束后,这个数组每一个小的内存空间就全部完成了,就有a[0]=0;a[1]=1,我们第一篇这个代码的目的是倒着输出,那么我们把这个时候就不是开辟地址了,而是数组值,那么我们把每一个值从9开始倒着输出,我们就得到了a[i]每一项的值

其实在我看来,数组是一个很方便的工具,其实它标准写我认为应该用指针代码完成它,因为数组本身就是指针,它的每一个都是地址,只是由于a的缘故迫使把它当作第一个位置a[0],在我们使用数组空间还是地址的时候就应该加上取值操作*或者取地址操作符号&,但是数组本身简化了它

二维数组也是一样,把那篇代码截取一部分出来大家看一下是否对于数组有了不一样的理解

#include 

int a[10][10];
int main() {
	int n, m;
	printf("每行每列控制为:");
	scanf("%d,%d", &n, &m);
	printf("该二维数组为:n");
	for (int i = 0; i < n; i++) {
		for (int j = 0; j < m; j++) {
			scanf("%d", &a[i][j]);
		}
	}
	int x, y;
	printf("想知道的:n");
	scanf("%d,%d", &x, &y);
	printf("这个元素为");
	printf("%d", a[x - 1][y - 1]); //数组 int a[m][n] 最大范围处的元素是 a[m–1][n–1]。
	return 0;
}

一样的,scanf和=都是赋值操作


我们继续python的学习,python也进入了循环的内容,所以返回来复习一下

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/352387.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号