10min快速回顾C++语法(一)
【摘要】 C++的语法奠基(一)⭐写在前面的话:本系列文章旨在短时间内回顾C/C++语法中的重点与易错点,巩固算法竞赛与写题过程中常用的语法知识,精准地解决学过但有遗忘的情况,为算法刷题打下坚实的基础。 一、详解一个标准的程序结构#include <iostream>using namespace std;int main(){ cout << "Hello World"<<endl; retur...
C++的语法奠基(一)
⭐写在前面的话:本系列文章旨在短时间内回顾C/C++语法中的重点与易错点,巩固算法竞赛与写题过程中常用的语法知识,精准地解决学过但有遗忘的情况,为算法刷题打下坚实的基础。
一、详解一个标准的程序结构
#include <iostream>
using namespace std;
int main()
{
cout << "Hello World"<<endl;
return 0;
}
1.1 常见头文件
#include <cstdio>
C标准的IO:里面有两个函数,printf与scanf。
#include <iostream>
cin>>读入; //想象是从cin中拿到变量中去
cout<<输出; //想象是从变量中输出到cout中去
注意:cout在输出浮点数时会默认保留为科学计数法的形式,要想去处这个形式,需要进行强制类型转化。
#include <cmath>
常见的数学函:sqrt(x)等等
1.2 using namespace std;
使用常见的命名空间:常见的库函数都在std这个命名空间里
- 只要保证在同一个命名空间里没有变量名冲突即可,不同的命名空间中出现冲突是没有关系的。
- 如果不加这句,那么在下面使用过程中就必须加上**std::**cout的符号
1.3 return
作为一个程序,最后一定是要返回0,如果不返回0,则代表有问题。
二、语法常识
2.1 变量
2.1.1 变量的类型
类型 | 关键字 | 范围 |
---|---|---|
布尔型 | bool | 0,1 |
字符型 | char | -128~127 |
整形 | int | ~ |
浮点型 | float | 6~7位有效数字 |
双浮点型 | double | 15-16位有效数字 |
#include <iostream>
using namespace std;
int main()
{
bool false/true 1Byte;
char 'a','c','/n' 1Byte;
//注意,在C++中char型必须用单引号'',单双引号意义不一样
int a = 1 4Bytes;
float b= 1.23, C = 1.23e2, d 4Bytes;
//float支持科学计数法
long long 范围为-2^63 ~2^63-1 8Bytes;
long long l = 100000000000000LL;
//末尾LL表示是LL类型的整数
long double 18~19位有效数字
}
2.1.2 Byte与bit
1Byte = 8bits
因此通常说的十兆带宽**(10Mb)实际下载速度约为1MB/s**
2.1.3 常见变量的IO方式
浮点数的IO
#include <cstdio>
#include <iostream>
using namespace std;
int main()
{
float a, b;
scanf("%f %f", &a, &b);
printf("a + b = %.1f \n a * b = %.2f", a + b, a * b);
//可以预先确定保留几位小数
double c, d;
scanf("%f %f", &c, &d);
printf("c + d = %lf \n c * d = %lf", c + d, c * d);
//double类型的IO
long long m ,n;
scanf("%lld %lld", &m, &n);
printf("m + n = %lld \n m * n = %lld", m + n, m * n);
return 0;
}
char的IO
#include <cstdio>
#include <iostream>
using namespace std;
int main()
{
float a, b;
scanf("%c %c", &a, &b);
//注意%c会读入空格的
//但是cin不会读入空格
printf("%c %c\n",a ,b );
return 0;
}
summary
常用类型
int | %d |
---|---|
char | %c |
float | %f |
double | %lf |
long long | %lld |
2.2 常见运算
2.2.1 %取模
注意%的取模操作(只能是整数),即取相除之后的余数。这里余数与数学中定义不一样,余数的正负取决于被除数和除数的正负
2.2.2 整数的自增和自减
++a | 先增后取值 |
---|---|
a++ | 先取值后增 |
简写
b = b + a ---->b += a
b = b % a ---->b %= a
取模时的a不能为0
2.3 变量类型之间的转换
隐形转换:把低精度转换为高精度
强制转换:(类型)变量 就可以
2.4 ASCII常用表
字符 | 十进制数字 |
---|---|
换行 | 10 |
空格 | 32 |
0 | 48 |
A | 65 |
a | 97 |
#include <cstdio>
#include <iostream>
using namespace std;
int main()
{
int t = 97;
char c = (char)t;
cout<< c <<endl;
return 0;
}
【版权声明】本文为华为云社区用户原创内容,未经允许不得转载,如需转载请自行联系原作者进行授权。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)