对于python来说,我们可以跳过定义直接使用“=”为变量名赋值。但是C++有严格的声明、定义调用流程,因此在赋值之前必须对需要用到的变量进行声明和定义:
# include // 引用头文件
# include
using std::string; // 可以使用字符串类
using namespace std; // 指定命名空间,以便
// 在代码中使用该命名空间中定义的所有标识符
// 类似于python中的from XXX import *
int main() // 定义主函数
{
int a; // 定义一个变量a,用于存储int类型数据
}
在C++中,主函数与其他函数一样,需要有函数类型、函数参数,但在python中,我们不需要通过主函数来告诉编译器执行哪些内容。本文之后的C++代码将不再写全引用和主函数,如果大家想要运行记得自行补全。
C++语言在声明变量的时候就可以为变量赋值,方式如下:
int a=10;
int b=10,c=10;
但需要注意的是,赋值之前必须要保证变量是有定义的,这就意味着一下写法是不能正常执行的:
int a=b=c=10; // 赋值语句从右向左进行,但b和c没有定义
C++中,虽然也可以使用scanf和printf作为输入和输出,但是使用系统函数cin和cout完成这一任务更为方便。
首先介绍输出,输出的语法为cout加两个小于号再加输出内容,我们可以在一行内多次数用两个小于号输出不同内容:
int a,b,c; // int是一个整数类,会自动给其实例赋初值,这点与Python相似。
// 不了解类和面对对象的小伙伴先不要着急,后面会讲到~
cout<<a;
cout<<b<<c;
运行上面的代码可以发现,终端输出a的值后,并没有换行或空格,而是紧接着输出了b和c的值。如果想要换行,除了使用cout<<“\n”;语句之外还可以在接输输出时加入endl:
int a,b,c;
cout<<a<<endl;
cout<<b<<c<<endl;
介绍过cout之后,我们再来看看cin。与cout类似,输入的语法为cin加两个大于号再加用于接收的内存空间。同理,我们也可以用多组双大于号来一次性指定多个变量进行接收:
int a,b,c;
cout<<"输入整数:";
cin>>a>>b>>c;
/*
或可写成
cin>>a;
cin>>b;
cin>>c;
*/
cout<<"\n"<<a<<b<<c<<endl;
通过以上代码我们可以键入三个数,并由变量a、b、c接收。输入过程以空格或回车作为结束标志。在计算机读到回车后,会判断输入是否结束。下面我们运行代码分析计算机具体怎样实现:
以上,分别是四次键入的效果。第一次,我们输入一个数字后按一次回车,在输入三次后,计算机会自动结束输入,执行cout输出。第二次,我们以空格作为分隔,在输入五个数字后按回车,可以看到计算机会自动将对应数字赋值给三个变量,当变量全被赋值后,会自动结束赋值,多输入的数字不会保存。第三次输入时1与2之间有两个空格,但计算机在读到第一个回车后并没有终止输入,说明多个空格和一个空格作为输入的分隔时拥有相同的效果。第四次输入时每个数字后面都跟着一个空格和一个回车,计算机依然在读到三个数后才结束输入过程。
在Python中,键入使用的是input,输出则使用print。由于Python使用空间之前不需要声明类型,所以默认的输入类型为字符串,并且空格不能被作为分割符记录,而是会被当做是输入的字符,只有遇到会车时,输入才会停止:
val=input("输入内容:")
print(val,type(val))
# 输出为:输入内容:1 2 3 4
# 1 2 3 4
如果我们希望输入内容为其他类型,可以在接收后进行类型转换。
在之前python的学习中,我们已经学到过python中承认的逻辑运算符号,典型的有and,or和not。C++显然是不支持这些英文单词作为逻辑运算符的,其表达与、或、非的逻辑关系分别用符号:
&&、||、!
需要注意的是,这种表达python是接受的:
int a=10,b=8;
cout<<(a&&b)<<" "<<(a||b)<<" "<<(!a)<<endl;
// 输出为1 1 0
在C++中,布尔类型的值依然只有0和1,其中0代表false,1则代表true。如果用普通数字用来描述false和true,那么0表示false,非0均为true。
如果我们只写了一个&或者|表示的则是数字二进制表示的按位与和按位或,python也同样适用。此外,常见的安慰操作符还有按位亦或“^”:
int a=10,b=8;
// 10=1010 8=1000
cout<<(a&b)<<endl; // 每一个对应位值均为1时记录1,否贼记录0。=1000
cout<<(a|b)<<endl; // 每一个对应位值均为0时记录0,否贼记录1。=1010
cout<<(a^b)<<endl; // 每一个对应位值不同时记录1,相同则记录0。=0010
// 输出为:8
// 10
// 2
移位操作符在python和C++中是相同的,这里就不过多展开了。
C++没有像python中那样方便的列表、字典等类型,可以轻易地添加新的元素。因此如果想要为数组等型增加长度时,就首先需要扩充数组的长度,具体扩大多少就需要看你想要添加多少元素,以及每个元素所占的空间。sizeof函数就可以完成计算每种类型所占空间大小(单位:字节)的计算:
int a;
std::string b;
float c;
double d;
cout<<sizeof(a)<<" "<<sizeof(b)<<" "<<sizeof(c)<<" "<<sizeof(d)<<endl;
// 输出为:4 32 4 8
python中有计算可迭代类型长度的函数len,但是在C++中,我们想要计算数组的长度就只能通过数组所占空间的总大小除以数组每个元素所占空间的大小间接得出:
char a[10];
cout<<sizeof(a)/sizeof(a[0]);
// 输出为:10
提起判断,大家都熟悉的一定是if-else语句。在python中,该语句写成:
if 条件A:
elif 条件B:
else:
而在C++中写法则略有不同:
if(条件A){}
else if(条件B){}
else{}
我们只需要注意一下写法上的不同就可以了。但是C++还支持一种python中没有的判断句switch:
switch(表达式)
{
case :
case :
.
.
.
default:
}
switch语句的括号里根着的表达式可以有非单纯0或1的多重结果,也可以不是数字。case后面要跟表达式的可能结果,default后面不需要跟内容。Switch语句中,每个冒号后面不用额外添加花括号,但是每个case和default在结束前必须要加一个break,否则如果中间的case满足了表达式的条件,这个case后面的语句将逐条被执行(自动忽略case),直到遇到break。原则上default要放在最后面,如果case成立,default将自动不会执行,所以即使case没有加break,default下的语句也不会在某条case成立时执行。下面给大家展示一个例子:
这段代码给到大家:
char a;
cout<<"请输入字母:";
cin>>a;
switch (a)
{
case 'a':
cout<<'a'<<endl;
// break;
case 'b':
cout<<'b'<<endl;
// break;
case 'c':
cout<<'c'<<endl;
break;
case 'd':
cout<<'d'<<endl;
// break;
default:
cout<<"not fond"<<endl;
// break;
}
有兴趣的小伙伴可以自行实验。
goto也是C++的特有,其可以强制程序跳转到另一位置执行,类似于循环。但是由于goto的规范使用难度较高,滥用goto又会导致代码可读性和可维护性变差,所以python禁用了这个语句。因为该语句并不推荐使用,所以我仅做简单的介绍:
int a=0,i=0;
lable:
a++;
cout<<a<<' ';
if(i<10)
{
i++;
goto lable; // 强行跳转到lable标记处
}
这样我们就利用强制跳转实现了一个执行十次的循环。
本节我们简单介绍了C++中一些基本的语句、逻辑判断和运算,并与Python进行了一些对比。相信看过我Python专栏的小伙伴可以很好的理解。其实,不同的语言只是在语法上有较大的差异,在算法实现的逻辑上则没有太大不同。下一节我会继续分享C++的循环和函数。