本文我们来讲C++知识精讲的第10篇,C++知识精讲10——递增序列双循环条件语句位运算写法(基本方法,后面的知识精讲会出详细的位运算讲解),此专栏会讲许多,各种各样的类型,如果喜欢此专栏请订阅持续关注,感谢大家的支持。接下来,进入今天的知识精讲。
位运算符号:
注:之前有文章梳理过(亿遍了),为了文章完整性此文章再次梳理一遍:
位运算符 | 作用 | 运算规则 |
---|---|---|
& | 位与 | 两个位都为1时,结果才为1。 |
| | 位或 | 两个位都为0时,结果才为0。 |
^ | 异或 | 两个位相同为0,相异为1。 |
~ | 取反 | 0变1,1变0。 |
<< | 左移 | 各二进位全部左移若干位,高位丢弃,低位补0。 |
>> | 右移 | 各二进位全部右移若干位,对无符号数,高位补0,有符号数,右移补1。 |
实战带入知识点
实战导入
读取一系列的整数 X,对于每个 X,输出一个 1,2,…,X的序列。
输入格式
输入文件中包含若干个整数,其中最后一个为 0,其他的均为正整数。
每个整数占一行。
对于输入的正整数,按题目要求作输出处理。
对于最后一行的整数0,不作任何处理。
输出格式
对于每个输入的正整数 X,输出一个从 1 到 X 的递增序列,每个序列占一行。
数据范围
1≤X≤100
输入样例:
5
10
3
0
输出样例:
1 2 3 4 5
1 2 3 4 5 6 7 8 9 10
1 2 3
算法分析
这个题一看很明显要用双循环求解,知识点就是在第一个while循环的条件上了,现在我们上代码,在代码中看知识点。
代码实现
第一种代码:
#include<iostream>
#include<cstdio>
using namespace std;
int main(){
int x;
while(cin>>x && x){
for(int i=1;i<=x;i++){
cout<<i<<' ';
}
cout<<endl;
}
return 0;
}
看这一条代码while的条件为cin>>x,目的是为了无限的循环,只要读入x就开始循环,cin本来就是有返回值的,在输入输出是看不见的,但是在后台是看得见的,就是-1或者EOF。然后条件里面就是一个位运算&&号,与一个x,等同于:
if(x==0)break;
break就是强制退出循环的方式,return 0也可以实现。
第二种代码:
#include<iostream>
#include<cstdio>
using namespace std;
int main(){
int x;
while(true){
cin>>x;
if(!x)return 0;
else {
for(int i=1;i<=x;i++){
cout<<i<<' ';
}
cout<<endl;
}
}
return 0;
}
看这个代码,true就是开一个无限循环,读入x,在判断,和上一个代码意思相同,表达方式不用。
第三种代码:
#include<iostream>
#include<cstdio>
using namespace std;
int main(){
int x;
while(~scanf("%d",&x)&&x){
for(int i=1;i<=x;i++){
cout<<i<<' ';
}
cout<<endl;
}
return 0;
}
这个代码可以看到可以用scanf输入条件,scanf前面有一个“~”符号,就是反一个值,等价于:
!=-1
也就是==true,以上都是同一个意思,只要真,就循环,再加上一个&&x就代替了:
if(x==0)break;
输出结果
1 2 3 4 5
1 2 3 4 5 6 7 8 9 10
1 2 3
注:以上各种代码形式的输出结果都是如此。
小结
这就是C++知识精讲10——递增序列双循环条件语句位运算写法(基本方法,后面的知识精讲会出详细的位运算讲解),把知识点带入实战,如有疑问,请在评论区留言,作者看到后,会一一回复的。