🚓Pixiv ID:42795418

while的循环体系



while的循环体系【1】

我之前写了很多很杂的细小的但是很实用的知识点,当然如果你想快点结束基础的知识点也可以不管前面的东西~~(比赛时你会哭)~~
还有别问我为什么跳过了for循环~~(我才不会告诉你我找了人帮忙)~~

那么废话不多说我们开始:

  • 语句格式:
    1.格式1:
     while(条件表达式)
       语句1; 
    
    2.格式2:
    while(条件表达式)
    { 
       语句1;
       语句2;
        ………… 
    }
    
    这里和之前的ifandswitch一样需要用花括号{}划分势力范围,否则只有下一条语句为它的势力范围
    建议:所有的if,switch,for,while都明确的用{}分好代码块(只有一条语句也一样,或者只有一条语句的话缩进2格)
  • 语句执行说明:

1.条件表达式的值用X代替
2.若X为真,则执行while的语句块(循环体),否则离开while循环,结束while语句。
3.在执行完一遍循环体以后都会转到第一步,知道X为假。


  • 简单的运用。
    我又来讲骚话了:

今天,小红去小茗家玩,很开森,就是买了很多东西,但是小红不想给钱,想让小茗同学给钱,所以小红就告诉了小茗同学,他也同意了,但是他有一个要求:计算1~N的和大于10000,N的最小值,小红算出来他就请客。他说道这里还露出了一个邪恶的笑容,加了一个条件:不许上网!!小红就打算写一个程序,可惜他不会,但是他有你这个聪明可爱勇敢帅气迷人的朋友,你就用刚刚看了的while来写个程序帮助小红打败小茗,气死小茗。

我们现在只会一种循环,而且这种问题不是简单的for语句能够解决的,所以用while就会很方便:
我们只是需要两个变量:1.sum用于计算和 2.n用于计算数字和次数
while里面的条件表达式就只需要当和sum<10000就行了。

  • 简单的代码:
#include<iostream>
using namespace std;
int main()
{
    int n=1,sum=0;
	while(sum < 10000)
	{
		sum += n;
		++n;
	}
	cout<<"Min="<<n<<endl;
	return 0;
} 

运行结果:

解释

1.sum += n+=是一种二目运算符sum += n = sum = sum+n
2.++n++也是一种二目运算符++n = n=n+1
3.在进行累加的时候变量必须赋初值为0累乘的变量必须赋初值为1


while的循环体系【2】

我们之前的while是用结果来限制循环次数的,那么问题来了:1.如何准确的控制循环次数 2. 如何搞定死循环

我们可以慢慢来聊。


准确的控制循环次数

这一点呢,在for的循环中很容易达到,但是while语句中却有一点点的麻烦,一般遇到有确定的循环次数一般用for但是我们这是在学习所以用while准确控制循环次数也需要掌握。

  • 分析:
    1.我们需要用一个计数器来记录我们的循环次数。
    2.这个计数器在while语句的条件语句中有决定性的作用。
    3.计数器需要自动加减。

我们就输入一个[int]n,输出n个“这是第n次输出”

#include<iostream>
#include<cstdio>
using namespace std;
int main()
{
	int n,x;
	/*限制条件n, 
	计数器x*/ 
	cin>>n;
	while(x <= n)
	{
		cout<<"这是第"<<x<<"次输出"<<endl; 
		// 也可以写作printf("这是第%d次输出\n",x);
		x++;
	} 
	return 0;
}

等等!!什么玩意?没有输出?

这是一个非常经典的错误程序,计数器没有初始化,导致计数器被编译器赋了一些奇奇怪怪的值,至于这个值是多少自己可以看的,只需要调试一下:

看看吧,在定义一个变量以后会被编译器赋一些奇奇怪怪的值,而且一般都很大,所以计数器都需要初始化为0或1。

改正后:

#include<iostream>
#include<cstdio>
using namespace std;
int main()
{
	int n,x=0;
	/*限制条件n, 
	计数器x*/ 
	cin>>n;
	while(x <= n)
	{
		cout<<"这是第"<<x<<"次输出"<<endl; 
		// 也可以写作printf("这是第%d次输出\n",x);
		x++;
	} 
	return 0;
}


很不高兴的是为什么还有第0次,我们要解决它:
可以有两种方法:
1.在循环题使用X之前就自加:

#include<iostream>
#include<cstdio>
using namespace std;
int main()
{
	int n,x;
	/*限制条件n, 
	计数器x*/ 
	cin>>n;
	while(x <= n)
	{
		x++;
		cout<<"这是第"<<x<<"次输出"<<endl; 
		// 也可以写作 printf("这是第%d次输出\n",x);
	} 
	return 0;
}


2.在计数器的初始化的时候令X=1

#include<iostream>
#include<cstdio>
using namespace std;
int main()
{
	int n,x=1;
	/*限制条件n, 
	计数器x*/ 
	cin>>n;
	while(x <= n)
	{
		cout<<"这是第"<<x<<"次输出"<<endl; 
		// 也可以写作 printf("这是第%d次输出\n",x);
		x++;
	} 
	return 0;
}
  • 到这里我们就搞定了使用while准确控制循环次数。
    Next Turn

死循环

~~这应该是我最喜欢在信息技术课上向教师机发的东西了,只要你知道教师上几个大文件路径死循环调用就行了。~~这可千万别让我的老师知道。

言归正传,死循环在很多时候是很有用的,比如:你要烧一台电脑 你要做一个循环播放的功能。但是在竞赛中基本用不上,基于求知的原则我们还是看了吧。

别给我讲很多地方需要for的死循环,这都是可以用while来解决的。

我们想一想如何让while语句一直执行呢?那就让while的条件表达式一直为真不就好了?那么有下面几种方式让条件表达式一直为真:

  1. 让一个数初值为1,当大于0时循环,并在每次循环后加一:
#include<iostream>
#include<cstdio>
using namespace std;
int main()
{
    unsigned int n=1; 
	while(n > 0)
	{
		cout<<"这是第"<<n<<"次输出"<<endl; 
		// 也可以写作 printf("这是第%d次输出\n",x);
		n++;
	} 
	return 0;
}


2. 直接在条件表达式输入为一个非零的数(C++中非零为真)

#include<iostream>
#include<cstdio>
using namespace std;
int main()
{
    int n=1; 
	while(1)
	{
		cout<<"这是第"<<n<<"次输出"<<endl; 
		// 也可以写作 printf("这是第%d次输出\n",x);
		n++;
	} 
	return 0;
}

肯定还有更多的方法,但是个人建议使用第二种方法,更加的简洁。


The End


循环的嵌套

  • 终于要结束这该死的循环了,是不是很兴奋?先兴奋一下吧~~(我才不会告诉你前面只是最简单的)~~只不过既然决定了要学就坚持吧。
    那么就结束现在的循环阶段吧。

开心吧。哈哈哈哈废话就属我最多了吧。 千万别介意我话多啊

之前的选择嵌套我选择了0,(看不懂自己反省)毕竟我搞这个也只有10个人(觉得人多的也去反省),而且其它人也只搞了for(截至这篇完都还没有给我,2019.8.7 16:26)

算了,算了直接开始了,要不我就成水鬼了。


循环嵌套从字面上理解就是一个循环套上一个循环,就是这么简单。emmm……大概是这样的:

#include<iostream>
using namespace std;
int main()
{
	int n=0;//计数器——记下输出次数 
	//循环嵌套结构 
	for(int i=0; i<10 ;++i)//第一层循环 
	{
		for(int j=0; j<10 ;++j)//第二层循环 
		{
			++n;//每一次输出时,计数器加1 
			cout<<n<<"-"<<"I am so cute"<<endl;//进行不要脸地输出 
		}
	}
	return 0;
}

没有注释的看不懂的自己去写会儿作业
忽视我的输出内容
就是两层10次循环的嵌套 ,得到的次数就应该是10*10=100次了,至于到底对不对,我看把它跑起来就知道了。

可以看到我们跑了100次出来,(忽略我的截图不完整)
这就是很简单的一个循环


有问题直接给我发邮件xiemaths@gmail.com或者xyh798061533@163.com
QQ:2385708107
ZWT大佬QQ:1259249107
LYT大佬QQ:1622956497
(周末统一回复,原谅高二狗的苦)