C++第一阶段总结与拓展


编程初学者必经阶段:(入门操作)感觉好简单 -> (看他人演示)哇,神奇,有意思 -> (自行处理)嗯?怎么回事?什么情况?

其实,我们学习编程就像是在玩拼图,每拼一段时间不知后面该怎么做的时候,就得看看整体都什么效果了,还缺哪些部分,我们手里都是些什么拼图。我们先前几篇短文介绍了C++编程的入门知识点,按理说完全可以做出点东西来了,但真正去刷题时就会发现“纸上得来终觉浅”,因此,在这里来帮助大家做一下总结和拓展。

1、C++程序基本格式

#include <iostream>	// 头文件
using namespace std;	// 	命名空间
int main() {	// 主函数入口
	// 代码段
	return 0;	// 返回值
}

2、数据类型

类型关键字所占内存大小表示范围
布尔型bool1byte=8bit只能是0或者1
字符型char1byte=8bit-128~127(即-27 ~27-1)
短整型short2byte=16bit-32768~32767(即-215~215-1)
整型int4byte=32bit-2147483648~2147483647(即-231~231-1)
长整型long int8byte=64bit-263~263-1
浮点型float4byte=32bit-3.4E+38~3.4E+38
双浮点型double8byte=64bit-1.7E-308~1.7E+308
空类型void
字符串类型string不确定,视具体情况而定

注意:
(1)黄色高显为已学数据类型,其它在后续编程中也将逐渐涉及。
(2)以上数据类型所占内存大小是针对64位操作系统而言的,至于32位与其区别可自行百度了解。后面,我若有余力再给大家说说计算机操作系统吧。
关于各个数据类型所占内存大小,可以使用sizeof()函数计算得出,单位为字节,代码如下:

#include <iostream>
#include <cstring>
using namespace std;
int main() {
    cout << "bool: " << sizeof(bool) << endl;
    cout << "char: " << sizeof(char) << endl;
    cout << "short: " << sizeof(short) << endl;
    cout << "int: " << sizeof(int) << endl;
    cout << "long: " << sizeof(long) << endl;
    cout << "float: " << sizeof(bool) << endl;
    cout << "double: " << sizeof(bool) << endl;
    // cout << "void: " << sizeof(void) << endl;    // 会报错
    cout << "string: " << sizeof(string) << endl;
    return 0;
}

运行结果如下:

运行结果

3、变量

(1)命名规则

a.只能由字母、数字或者下划线组成;
b.开头不能是数字;
c.不能与C++关键字同名;
d.不能在同一代码段中重复定义;
e.区分大小写。

(2)定义方式

[数据类型] [变量名] ;
如:

int a, b, c;	// 定义三个整数
float d;	// 定义一个单精度浮点数
double e;	// 定义一个双精度浮点数
char ch;	// 定义一个字符

(3)初始化

定义变量的时候赋初始值叫做初始化,目的是防止后面直接使用出现异常结果。
如:

int a = 0, b = 1, c = 2;	// 定义三个整数,并分别初始化为0,1,2
float d = 3.14;	// 定义一个单精度浮点数,初始化为3.14
double e = 9.16;	// 定义一个双精度浮点数,初始化为9.16
char ch = 'z';	// 定义一个字符,初始化为z

4、运算符

运算符描述
+把两个操作数相加
-从第一个操作数中减去第二个操作数
*把两个操作数相乘
/分子除以分母
%取模运算符,整除后的余数
=将等号右边计算得到的结果赋值给等号左边的变量
+=将左边变量的值与右边的值相加,结果赋值给左边变量
-=将左边变量的值与右边的值相减,结果赋值给左边变量
*=将左边变量的值与右边的值相乘,结果赋值给左边变量
/=将左边变量的值与右边的值相除,结果赋值给左边变量
%=将左边变量的值与右边的值求余数,结果赋值给左边变量

运算符存在优先级,这与数学中是一致的,乘除取余高于加减。

5、表达式

由变量、运算符和数字组成,运算符类型决定着表达式类型,如:有赋值运算符的赋值表达式、有算术运算符的算术表达式等等。

a = 3
a + b
b / 5
6 * (c - 4)

6、语句

或者更具体些,应该叫做赋值语句,C++程序中的语句都是在做赋值操作,并以分号结尾
可能有人会说输入输出就没有在赋值啊,其实不然,输入输出语句也在做赋值,输入语句是将用户输入的值由输入流赋值给变量,输出语句是将用户计算的值赋值给输出流,再在终端显示。

7、输入与输出

(1)输入语句

第一种是C++独有的输出方式,它可以直接识别变量类型输出。

cin >> 变量a >> 变量b ;

第二种是C语言的格式化输入函数,它必须由程序员指明变量类型,否则会造成输入异常。
基本格式为:

int scanf(const char *format, ...)

使用样例如下:

#include<iostream>
using namespace std;
int main(void) 
{ 
    int a,b,c; 
    cout << "please input three numbers: " ;
    scanf("%d%d%d",&a,&b,&c); 	// %d表示整数
    cout << a << ' ' << b << ' ' << c << endl;
    return 0; 
}

scanf使用样例

具体类型说明符为:

scanf 类型说明符
更多内容可以查看:scanf的详细说明

(2)输出语句

第一种是C++独有的输出方式,它可以直接识别参数类型,然后输出。
基本格式为:

cout << 变量/语句 << 变量/语句 << endl;

第二种是C语言的格式化输出语句,它和scanf一样,需要程序员指定输出所对应的数据类型。
基本格式为:

int printf(const char *format, ...)

使用样例如下:

#include <iostream>
using namespace std;
int main ()
{
	int a = 3;
	float b = 1.2;
	double c = 3.4;
	char d = 'c';
	// %d表示整数, %f表示浮点数并保留6位小数
	printf("%d %f %f %c\n", a, b, c, d);	
	cout << a << ' ' << b << ' ' << c << ' ' << d << endl;
	return 0;
}

printf使用样例
具体字符说明符为:

字符说明符
其实,介绍printf主要是为了帮助大家解决一类题目:输出结果保留指定位数小数

直接上题目吧~

输入两个100以内的正整数a、b,计算 a / b 的值并输出,结果保留3位小数

代码如下:

#include <iostream>
using namespace std;
int main() {
    float a, b;
    cin >> a >> b;
    printf("%.3f\n", a / b); // %.3f表示保留3位小数
    // printf("%.4f\n", a / b); // %.4f表示保留4位小数
    // printf("%.5f\n", a / b); // %.5f表示保留5位小数
    return 0;
}

运行结果如下:
格式化输出
这就是格式化输出,除数值精度外,还可以自主控制宽度、长度、标识,具体内容可以查看:printf的详细说明

知识点内容挺多,还请大家好好消化吸收,多多动手练习!

在安言庆

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值