10min快速回顾C++语法(一)

举报
timerring 发表于 2022/08/09 23:23:15 2022/08/09
【摘要】 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 2 31 -2^{31} ~ 2 31 1 2^{31}-1
浮点型 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

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。