首页 > 编程语言 >蓝桥杯准备训练(lesson2 ,c++)

蓝桥杯准备训练(lesson2 ,c++)

时间:2024-12-04 18:03:35浏览次数:7  
标签:lesson2 signed int unsigned long 蓝桥 c++ 类型 整型

3.1 字符型

char //character的缩写

在键盘上可以敲出各种字符,如: a , q , @ , # 等,这些符号都被称为字符,字符是⽤单引号括
起来的,如: ‘a’ , ‘b’ , ‘@’ 。为了能说明这些字符,给他们抽象出⼀种类型,就是字符型,C
语⾔中就是 char 。

ASCII编码
我们知道在计算机中所有的数据都是以⼆进制的形式存储的,那这些字符在内存中分别以什么样的⼆进制存储的呢?如果我们每个⼈⾃⼰给这些字符中的每个字符编⼀个⼆进制序列,这个叫做编码,为了⽅便⼤家相互通信,不造成混乱,后来美国国家标准学会(ANSI)出台了⼀个标准 ASCII 编码,C语⾔中的字符就遵循了 ASCII 编码的⽅式。

在这里插入图片描述
参考:https://zh.cppreference.com/w/cpp/language/ascii
我们不需要记住所有的ASCII码表中的数字,使⽤时查看就可以,不过我们最好能掌握⼏组特殊的数据:
• 字符 A~Z 的ASCII码值从 65~90
• 字符 a~z 的ASCII码值从 97~122
• 对应的⼤⼩写字符(a和A)的ASCII码值的差值是 32
• 数字字符 0~9 的ASCII码值从 48~57
• 换⾏ \n 的ASCII值是: 10
• ASCII码值从0~31 这32个字符是不可打印字符,⽆法打印在屏幕上观察

#include<iostream>
using namespace std;
int main()
{
	char c1 = 'Q';
	cout << c1 << endl;
	char c2 = 81;
	cout << c2 << endl;
	//这⾥的81是字符Q的ASCII码值,也是可以正常打印的
	return 0;
}

3.2 整形

整型类型是对所有整数的抽象,为了能对整数形成统⼀的类型标识,就有整型;
在 C 和 C++ 中 整型被分为四⼤类: short 、 int 、 long 、 long long 。

short [int]//短整型
int//整型
long  [int]//⻓整型
long long [int] //更⻓的整型

3.3 浮点型

浮点型式对所有实数(⼩数)的抽象,为了能对实数进⾏统⼀的类型标识,就有了浮点型。
浮点型有三种:

float//单精度浮点型
double//双精度浮点型
long double//更⻓的双精度浮点型
#include<iostream>
using namespace std;
int main()
{
	char c = 'a';
	short s = -10;
	int i = -10;
	long l  = -10;
	long long ll = -10;
	float k = 3.14f;
	double d = 3.14;
	long double ld = 3.14;
	return 0;
}

在C/C++中⼩数的书写形式:

3.14;//编译器会默认识别为double类型
3.14f;//编译器会默认识别为float类型
1e5;//这种写法是科学计数法的形式,意思是1.0*10^5
1e5+10;//1*100000+10 == 100010
1.23e5+10; //1.23*100000+10 = 123010

3.4 布尔类型

C++有⼀种类型叫: bool (布尔类型),布尔类型的变量的值可以是 true 或 false ,这种类型
类型的变量专⻔⽤来表⽰真或假的。当然在C和C++中,0表⽰假,⾮0表⽰真,有时候不使⽤ bool 类型也能表达相同的逻辑。

//代码1
#include <iostream>
using namespace std;
int main()
{
	bool flag = true;
	if (flag)
		printf("I like C++!\n");
	return 0;
}
//代码2
#include <iostream>
using namespace std;
int main()
{
	int flag = 0;
	cin >> flag; //如果输⼊⾮零的值,flag就表⽰真
	if (flag)
		printf("I like C++!\n");
	return 0;
}

3.5 signed 与 unsigned

signed 和 unsigned 关键字修饰字符型和整型类型的。
signed 关键字,表⽰⼀个类型带有正负号,包含负值;⽐如:温度、银⾏存款。
unsigned 关键字,表⽰该类型不带有正负号,只能表⽰零和正整数,⽐如:年龄。
有了 signed 和 unsigned 的修饰,字符和整型类型其实更加丰富,可以有以下这些:

//字符型
char
signed char//有符号的字符类型
unsigned char //⽆符号的字符类型

//短整型
short [int]
[signed] short [int]//有符号的短整型
unsigned short [int]//⽆符号的短整型

//整型
int
[signed] int//有符号的整型
unsigned [int]//⽆符号的整型

//⻓整型
long [int]
[signed] long [int] //有符号的⻓整型
unsigned long [int] //⽆符号的⻓整型

//更⻓的整型
long long [int]
[signed] long long [int]//有符号的
unsigned long long [int]//⽆符号的

对于 int 类型,默认是带有正负号的,也就是说 int 等同于 signed int 。
由于这是默认情况,关键字 signed ⼀般都省略不写,但是写了也不算错。

signed int a;    //等同于int a,⼀般不写signed

int 类型也可以不带正负号,只表⽰⾮负整数。这时就必须使⽤关键字 unsigned 声明变量。

unsigned int a; // unsigned int:⽆符号整数类型

变量声明为 unsigned 的好处是,同样⻓度的内存能够表⽰的最⼤整数值,增⼤了⼀倍。
⽐如,16位的 signed short int 的取值范围是: -32768~32767 ,最⼤是 32767 ;⽽
unsigned short int 的取值范围是: 0~65535 ,最⼤值增⼤到了 65535 。32位的 signed
int 的取值范围可以参看 climits 中给出的定义。

下⾯的定义是Dev-C++环境中, climits 中相关定义,其实如果仔细看 climits 中也是包含的
limits.h 。

#define SHRT_MIN    (-32768)//有符号16位整型的最⼩值
#define SHRT_MAX      32767//有符号16位整型的最⼤值
#define USHRT_MAX     0xffffU//⽆符号16位整型的最⼤值
#define INT_MIN     (-2147483647 - 1)//有符号整型的最⼩值
#define INT_MAX       2147483647//有符号整型的最⼤值

unsigned int ⾥⾯的 int 可以省略,所以上⾯的变量声明也可以写成下⾯这样。

unsigned a;

字符类型 char 也可以设置 signed 和 unsigned 。

signed char c;// 范围为 -128 到 127
unsigned char c;// 范围为 0 到 255

3.6 数据类型⻓度

每⼀种数据类型都有⾃⼰的⻓度,使⽤不同的数据类型,能够创建出⻓度不同的变量,变量⻓度的不同,存储的数据范围就有所差异。

3.6.1 sizeof 操作符

sizeof 是⼀个关键字,也是操作符,专⻔是⽤来计算特定数据类型的⻓度的,单位是字节。
sizeof 操作符的操作数可以是类型,也可是变量名或者表达式, sizeof 的操作数如果不是类
型,是表达式的时候,可以省略掉后边的括号的。
sizeof( 类型 )
sizeof 表达式

sizeof 的计算结果是 size_t 类型的, size_t 指的是⽆符号整数(该类型包含了所有可能的
unsigned int , unsigned long , unsigned long long 等类型,具体是取决于编译器
的)。

#include <iostream>
using namespace std;
int main()
{
	int a = 10;
	cout << sizeof(a) << endl;
	cout << sizeof a << endl;
	//a是变量的名字,可以省略掉sizeof后边的(),但不建议去掉
	cout << sizeof(int) << endl;
	return 0;
}

3.6.2 各数据类型⻓度

#include <iostream>
using namespace std;
int main()
{
	cout << sizeof(char) << endl;
	cout << sizeof(bool) << endl;
	cout << sizeof(short) << endl;
	cout << sizeof(int) << endl;
	cout << sizeof(long) << endl;
	cout << sizeof(long long) << endl;
	cout << sizeof(float) << endl;
	cout << sizeof(double) << endl;
	cout << sizeof(long double) << endl;
	return 0;
}

在DevC++下的输出:

1
1
2
4
4
8
4
8
16

该如何理解这些数据类型的⻓度呢?其实我们使⽤这些数据类型可以向内存申请空间(就是创建变
量),不同的数据类型⼀次性申请的空间⼤⼩是有差异的。你可以这样理解:
在这里插入图片描述

3.7 各类型取值范围

前⾯的知识已经让我们了解到了很多的数据类型,不同的数据类型所创建的变量的⻓度是有差异的,这个⻓度差异⼜决定了,这种变量中能存储的值的⼤⼩。
其实每⼀种数据类型有⾃⼰的取值范围,也就是存储的数值的最⼤值和最⼩值的区间,有了丰富的类型,我们就可以在适当的场景下去选择适合的类型。
下⾯是不同数据类型的取值范围。
在这里插入图片描述

为了代码的可移植性,和⽅便记忆,需要知道某种整数类型的极限值时,经常使⽤这些速记的符号。
limits.h ⽂件中说明了整型类型的取值范围。(C++中头⽂件的名字是 )
float.h 这个头⽂件中说明浮点型类型的取值范围。(C++中头⽂件的名字是 )
⼤家对这些类型的取值范围还得⼤概知道取值范围的数量级,像 int 类型取值⼤概就
是:-2.1*109~2.1*109,这⾥就是10^9这样的数量级。

3.8 typedef

在C++中有⼀个关键字是和类型有关的,是⽤来给类型重命名的。当有⼀个类型⽐较复杂的时候,可以简化类型。 typedef 在竞赛中经常使⽤,可以提升编码速度。typedef使⽤的基本语法形式:
typedef 旧类型名 新类型名;
⽐如:
typedef unsigned int uint;
typedef long long ll;
typedef unsigned long long ull;

上⾯代码的意思是将 unsigned int 类型重命名为 uint ,使⽤ uint 创建的变量和使⽤
unsigned int 是⼀样的,其他⼏个也是⼀样的道理。
uint num1 = 0;//等价于 unsigned int num1 = 0;
ll num2 = 0; //等价于 long long num2 = 0;
ull num3 = 0; //等价于 unsigned long long num3 = 0;

3.9 课后练习

练习1:整数

链接:https://ac.nowcoder.com/acm/problem/21985

#include <iostream>
using namespace std;
int main()
{
	int a;
	cin >> a;
	cout << a;
	return 0;
}

练习2:打印字符

链接:https://www.luogu.com.cn/problem/B2018

#include <iostream>
using namespace std;
int main()
{
	int n = 0;
	cin >> n;
	char ch = n;
	cout << ch << endl;
	return 0;
}

练习3:倒序

链接:https://ac.nowcoder.com/acm/problem/21993

#include <iostream>
using namespace std;
int main()
{
	int a = 0;
	int b = 0;
	int c = 0;
	cin >> a >> b >> c;
	cout << c << " " << b << " " << a << endl;
	return 0;
}

练习4:整型数据类型存储空间⼤⼩

链接:http://ybt.ssoier.cn:8088/problem_show.php?pid=1016

#include <iostream>
using namespace std;
int main()
{
	int n = 0;
	short s = 0;
	cout << sizeof(n) << " " << sizeof(s) << endl;
	return 0;
}

以上就是今天所有的学习内容,由于我们从最基础开始学习,希望大家不要觉得题目太简单就直接跳过,防止与课程进度脱节。

标签:lesson2,signed,int,unsigned,long,蓝桥,c++,类型,整型
From: https://blog.csdn.net/2401_87257864/article/details/144245602

相关文章

  • 蓝桥杯准备训练(lesson1,c++方向)
    前言报名参加了蓝桥杯(c++)方向的宝子们,今天我将与大家一起努力参赛,后序会与大家分享我的学习情况,我将从最基础的内容开始学习,带大家打好基础,在每节课后都会有练习题,刚开始的练习题难度很低,但希望大家也简单的做一下,防止与课程脱节,最后希望大家都能取得好成绩。1、工具安装......
  • 【C++入门】【六】
    本节目标一、继承的概念及定义二、基类和派生类对象赋值转换三、继承中的作用域四、派生类的默认成员函数五、继承与友元六、继承与静态成员七、复杂的菱形继承及菱形虚拟继承八、继承的总结和反思九、笔试面试题一、继承的概念及定义1.继承的概念继承......
  • 打卡信奥刷题(360)用C++工具信奥P3353[普及组/提高] 在你窗外闪耀的星星
    在你窗外闪耀的星星题目背景飞逝的的时光不会模糊我对你的记忆。难以相信从我第一次见到你以来已经过去了3年。我仍然还生动地记得,3年前,在美丽的集美中学,从我看到你微笑着走出教室,你将头向后仰,柔和的晚霞照耀着你玫瑰色的脸颊。我明白,我已经沉醉于你了。之后,经过几个月......
  • Python扩展C/C++ 实现原理分析
    Python扩展C/C++实现原理分析https://blog.csdn.net/HaoBBNuanMM/article/details/112243129?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522ab2ac79057d38453c0328d6726560514%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fblog.%2522%257D&request......
  • 蓝桥杯二分题
    P1083[NOIP2012提高组]借教室题目描述在大学期间,经常需要租借教室。大到院系举办活动,小到学习小组自习讨论,都需要向学校申请借教室。教室的大小功能不同,借教室人的身份不同,借教室的手续也不一样。面对海量租借教室的信息,我们自然希望编程解决这个问题。我们需要处理接......
  • 蓝桥杯分治
    P1226【模板】快速幂题目描述给你三个整数 ......
  • 《 C++ 点滴漫谈: 六 》不可改变的力量:const 编程世界的安全卫士
    摘要const关键字是C++中不可或缺的组成部分,其核心作用在于提升代码的安全性、可读性和性能优化能力。本文深入剖析了const的基本概念及其在变量、函数、指针、引用和类中的具体应用,同时详细解析了const_cast的用法与潜在风险。此外,文章探讨了const的优势与局限,为......
  • C++ ——— 引用的概念以及特性
    引用的概念引用不是新定义一个变量,而是给已存在的变量取了一个别名,编译器不会为引用变量开辟内存空间,它和它引用的变量共用同一块内存空间引用的关键字:&引用的基本语法:inta=0;int&b=a;在内存中开辟了一块空间,这块空间的名字为a,并且在这块空间里存储了0这个值......
  • C++项目提示“error MSB4019: 找不到导入的项目”
    报错:C:\Users\DELL\Desktop\PDManager-20240912(1)\PDManager\PDManager\PDManager.vcxproj(66,5):errorMSB4019:找不到导入的项目“D:\VisualStudio\2022\Community\MSBuild\Microsoft\VC\v170\BuildCustomizations\CUDA11.6.props”。请确认Import声明“D:\Visual......
  • 【C++】sort
    sort基本功能在C++算法库中,sort函数主要用于对给定范围内的元素进行排序。它是一种高效的排序算法,通常基于快速排序(QuickSort)的思想实现,并且在某些情况下会自动切换到插入排序(InsertionSort)以优化性能。头文件需要包含才能使用sort函数。函数原型最常用的形式......