GESP C++三级 知识点讲解
C++编程三级标准
(一)知识点详述
(1)了解二进制数据编码:原码、反码、补码。
(2)掌握数据的进制转换:二进制、八进制、十进制、十六进制。
(3)掌握位运算:与(&)、或(|)、非(~)、异或(^)、左移(<<)、右移(>>)的基本使用方法及原理。
(4)了解算法的概念与描述,熟练运用自然语言、流程图、伪代码方式来描述算法。
(5)C++一维数组基本应用;
(6)掌握字符串及其函数的使用包括但不限于大小写转换、字符串搜索、分割、替
换。
(7)理解枚举算法、模拟算法的原理及特点,可以解决实际问题,
(8)理解模拟算法、模拟算法的原理及特点,可以解决实际问题。
(二)考核目标
掌握计算机中常用进位制、位运算及数据编码的知识,掌握一维数组、字符串类型及其函数的使用,掌握枚举法、模拟法的原理和运用技巧,对于较简单的实际问题能构造算法、描述算法、实现算法并调试程序。
1、二进制数据编码:原码、反码、补码
2、数据的进制转换:二进制、八进制、十进制、十六进制
3、位运算:与(&)、或(|)、非(~)、异或(^)、左移(<<)、右移(>>)的基本使用方法及原理
(1)& 按位与
如果两个相应的二进制位都为1,则该位的结果值为1,否则为0
(2)| 按位或
两个相应的二进制位中只要有一个为1,该位的结果值为1
(3)^ 按位异或
若参加运算的两个二进制位值相同则为0,否则为1
(4)~ 取反
~是一元运算符,用来对一个二进制数按位取反,即将0变1,将1
举例:
1000101 1000101 1000101 1000101
& 0101100 | 0101110 ~ ^ 0101110
= 0000100 = 1101111 = 0111010 1101011
(5)<< 左移
用来将一个数的各二进制位全部左移n位,低位以0补充,高位越界后舍弃。
1左移n位: 1 << n=2^n(这里指2的n次方)
n左移1位: n << 1=n*2
举例:
short a=9115 0010001110011011 (9115的二进制表示)
a << 1 =18230 0100011100110110 (注意高位越界后舍弃一个0,低位填充一个0)
a << 2 = -29076 1000111001101100 (注意高位越界后舍弃两个0,低位填充两个0)
【注意】在C++中,当对一个有符号整数进行左移运算(
<<)时,如果左移导致符号位(最高位)变为1,那么这个数会被解释为一个负数。此时,计算其十进制值时,需要使用补码来表示和计算。
【注意】左移是做乘2的运算,但这是在符号位(原码将最高位符号以0表示正,1表示负eg:0010001110011011中的最高位0就是符号位,表示是正数;而1000111001101100最高位是1,表示是负数)不变的情况下。如果符号位发生了改变,说明已经不能做乘2的运算了,否则会溢出,得到的值不是乘2的结果。
【注意】short是Java中的表示,它定义的也是整形,不过是16字节(这里为了阐述符号位的改变而使用),而int是32字节
(6) >> 右移
将一个数的各二进制位右移n位,移到右端的低位被舍弃,高位以符号位填充
n右移1位 : n >> 1=|n/2.0|
算术右移等于除以2向下取整,(-3)>> 1 = -2 ,3 >> 1 = 1
值得一提的是,“整数/2”在c++中实现为“除以2向零取整”,(-3)/ 2 = -1,3 / 2 = 1
举例:
short b = 9115 0010001110011011
(9115 >> 1) = 4557 0001000111001101(注意低位越界后舍去了一个1,高位补一0)
(9115 >> 2) = 2278 0000100011100110 (注意低位越界后舍去了两个1,高位补两0)
short c=-32766(负数符号位为1) 1000000000000010
-32766 >> 1 = -16383 1100000000000001(注意低位越界后舍弃一个0,高位补1)
-32766 >> 2 = -8192 1110000000000000(注意低位越界后舍弃0和1,高位补俩1)
6、字符串及其函数的使用包括但不限于大小写转换、字符串搜索、分割、替换。
(1)s.insert(pos,args)
解释:在pos之前插入args指定的字符。
例:string s="stacde";
s.insert(0,"ab");
结果:abstacde
(2)s.erase(pos,len)
解释:删除从pos开始的len个字符,如果len省略,则删除从pos开始的后面所有字符,返回一个指向s的引用。
例1:string s=”abcdefg“;
s.erase(3,2);
结果:abcfg
例2:string s=”abcdefg“;
s.erase(3);
结果:abc
(3)s.assign(args)
解释:将s中的字符替换为args指定的字符,返回一个指向s的引用。
例:string s=”cdefojt“;
s.assign(”abc“);
结果:abc
(4)s.append(args)
解释:将args追加到s,返回一个指向s的引用,args必须是双引号字符串。
例:string s=”abcdef“;
s.append(”abc“);
结果:abcdefabc
(5)s.replace(range,args)
解释:将s中范围为range内的字符串替换为args指定的字符。
例1:string s=”qewffdgsgsdrew“;
s.replace(2,4,”abc“);
结果:qeabcgsgsdrew
注:从第2个字符,数4个字符,然后换成abc。
例2:string s=”abcdef“;
s.replace(1,2,”abc“);
结果:aabcdef。
例3:string s=”abcdef“;
s.replace(1,3,”abc“);
结果:aabcef。
(6)s.rfind(args)
解释:查找s中args最后一次出现的位置。
例1:string s=”abcdefabc“;
int t=s.rfind(”abc“);
结果:6
例2:string s=”defhob“;
int t=s.rfind(”abc“);
结果:-1
(7)s.find(args)
解释:查找s中args第一次出现的位置。
例1:string s=”bcabcdef“;
int t=s.find(”abc“);
结果:2
例2:string s=”defhobc“;
int t=s.find(”abc“);
结果:-1
(8)to_string(val)
解释:将数值val转换为string并返回,val可以是任何算术类型(int,float,double等)。
例1:string s=to_string(12345);
结果:12345
例2:string s=to_string(12345.123);
结果:12345.123000
(9)stoi(s)
解释:将字符串转换为整数并返回。
例1:int t=stoi(”12345“);
结果:12345
例2:int t=stoi(”12345.123“);
结果:12345
(10)stof(s)
解释:将字符串转换为浮点数并返回。
例:double a=stof(”12345.12345);
cout<<a<<endl;
printf("%.5lf",a);
结果:12345.1
12345.12345
(11)s.substr(pos,n)
解释:从索引pos开始,提取连续的n个字符,包括pos位置的字符。
例:string s=”abcdef“;
s.substr(2,2);
结果:cd
(12)reverse(s2.begin(),s2.end())
解释:反转string定义的字符串s2(加头文件<algorithm>)
例1:string s=”abcdefg“;
reverse(s.begin(),s.end());
结果:gfedcba
例2:string s=”abcdefg“;
reverse(s.begin(),s.end()-1);
结果:fedcbag
相关文章:
GESP C++三级 知识点讲解
C编程三级标准 (一)知识点详述 (1)了解二进制数据编码:原码、反码、补码。 (2)掌握数据的进制转换:二进制、八进制、十进制、十六进制。 (3)掌握位运算:与(&)、或(|)、非(~)、异或(^)、左移(<<)、右移(>>)的基本使用方法及原理。 (4)了解算法的概念与描述&…...
前端 vs 后端:技术分工详解——从用户界面到系统逻辑的全解析
前端(Frontend) 和 后端(Backend) 是软件开发中两个核心概念,分别对应用户直接交互的部分和系统背后的逻辑处理部分。它们共同构成完整的应用程序,但分工不同。 目录 一、前端(Frontend…...
Redis 除了数据类型外的核心功能 的详细说明,包含事务、流水线、发布/订阅、Lua 脚本的完整代码示例和表格总结
以下是 Redis 除了数据类型外的核心功能 的详细说明,包含事务、流水线、发布/订阅、Lua 脚本的完整代码示例和表格总结: 1. Redis 事务(Transactions) 功能描述 事务通过 MULTI 和 EXEC 命令将一组命令打包执行,保证…...
JavaScript智能对话机器人——企业知识库自动化
引言 内部知识管理常面临信息分散、查找困难的问题。本文将使用Node.js和虎跃办公的智能对话API,构建企业级知识问答机器人,支持自然语言查询和自动学习。 核心技术 自然语言处理(NLP)意图识别机器学习模型微调REST API集成 代…...
JS实现AES和DES
目录 目标 概述 DES AES 实战 JS实现DES JS实现AES 目标 了解AES和DES的特点并用JS实现。 概述 DES 翻译过来叫数据加密标准。它有5种加密模式(CTR、OFB、CFB、CBC、ECB),在JS中,不同加密模式语法结构几乎一致,…...
【C++11(下)】—— 我与C++的不解之缘(三十二)
前言 随着 C11 的引入,现代 C 语言在语法层面上变得更加灵活、简洁。其中最受欢迎的新特性之一就是 lambda 表达式(Lambda Expression),它让我们可以在函数内部直接定义匿名函数。配合 std::function 包装器 使用,可以…...
Windows 10/11系统优化工具
家庭或工作电脑使用时间久了,会出现各种各样问题,今天给大家推荐一款专为Windows 10/11系统设计的全能优化工具,该软件集成了超过40项专业级实用程序,可针对系统性能进行深度优化、精准调校、全面清理、加速响应及故障修复。通过系…...
浅谈在HTTP中GET与POST的区别
从 HTTP 报文来看: GET请求方式将请求信息放在 URL 后面,请求信息和 URL 之间以 ?隔开,请求信息的格式为键值对,这种请求方式将请求信息直接暴露在 URL 中,安全性比较低。另外从报文结构上来看,…...
LightRAG实战:轻松构建知识图谱,破解传统RAG多跳推理难题
作者:后端小肥肠 🍊 有疑问可私信或评论区联系我。 🥑 创作不易未经允许严禁转载。 姊妹篇: 2025防失业预警:不会用DeepSeek-RAG建知识库的人正在被淘汰_deepseek-embedding-CSDN博客 从PDF到精准答案:Coze…...
C++多线程编码二
1.lock和try_lock lock是一个函数模板,可以支持多个锁对象同时锁定同一个,如果其中一个锁对象没有锁住,lock函数会把已经锁定的对象解锁并进入阻塞,直到多个锁锁定一个对象。 try_lock也是一个函数模板,尝试对多个锁…...
垃圾回收——三色标记法(golang使用)
三色标记法(tricolor mark-and-sweep algorithm)是传统 Mark-Sweep 的一个改进,它是一个并发的 GC 算法,在Golang中被用作垃圾回收的算法,但是也会有一个缺陷,可能程序中的垃圾产生的速度会大于垃圾收集的速度,这样会导…...
Linux学习笔记——零基础详解:什么是Bootloader?U-Boot启动流程全解析!
零基础详解:什么是Bootloader?U-Boot启动流程全解析! 一、什么是Bootloader?📌 举个例子: 二、U-Boot 是什么?三、U-Boot启动过程:分为两个阶段🔹 第一阶段(汇…...
Windows环境下开发pyspark程序
Windows环境下开发pyspark程序 一、环境准备 1.1. Anaconda/Miniconda(Python环境) 如果不怕包的版本管理混乱,可以直接使用已有的Python环境。 需要安装anaconda/miniconda(python3.8版本以上):Anaconda…...
thinkphp8.0上传图片到阿里云对象存储(oss)
1、开通oss,并获取accessKeyId、accessKeySecret <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8" /><meta name"viewport" content"widthdevice-width, initial-scale1.0" /><tit…...
SSM婚纱摄影网的设计
🍅点赞收藏关注 → 添加文档最下方联系方式咨询本源代码、数据库🍅 本人在Java毕业设计领域有多年的经验,陆续会更新更多优质的Java实战项目希望你能有所收获,少走一些弯路。🍅关注我不迷路🍅 项目视频 SS…...
1110+款专业网站应用程序UI界面设计矢量图标figma格式素材 Icon System | 1,100+ Icons Easily Customize
1110款专业网站应用程序UI界面设计矢量图标figma格式素材 Icon System | 1,100 Icons Easily Customize 产品特点 — 24 x 24 px 网格大小 — 2px 线条描边 — 所有形状都是基于矢量的 — 平滑和圆角 — 易于更改颜色 类别 🚨 警报和反馈 ⬆️ 箭头 &…...
nacos的地址应该配置在项目的哪个文件中
在 Spring Boot 和 Spring Cloud 的上下文中,Nacos 的地址既可以配置在 bootstrap.yml 中,也可以配置在 application.yml 中,但具体取决于使用场景和需求。以下是两者的区别和最佳实践: 1. bootstrap.yml vs application.yml …...
Llama 4 家族:原生多模态 AI 创新的新时代开启
0 要点总结 Meta发布 Llama 4 系列的首批模型,帮用户打造更个性化多模态体验Llama 4 Scout 是有 170 亿激活参数、16 个专家模块的模型,同类中全球最强多模态模型,性能超越以往所有 Llama 系列模型,能在一张 NVIDIA H100 GPU 上运…...
OpenCV 在树莓派上进行实时人脸检测
这段 Python 代码借助 OpenCV 库实现了在树莓派上进行实时人脸检测的功能。它会开启摄像头捕获视频帧,在每一帧里检测人脸并以矩形框标记出来,同时在画面上显示帧率(FPS)。 依赖库 cv2:OpenCV 库,用于计算…...
SMT加工贴片核心工艺解析
内容概要 表面贴装技术(SMT)作为现代电子制造的核心工艺,其加工流程的精细度直接影响产品性能和良率。本文系统性梳理SMT贴片生产的全链条技术节点,以焊膏印刷、元件贴装、回流焊接三大核心工序为轴线,剖析各环节的工…...
嵌入式Linux驱动开发基础知识(三)
Linux系统与驱动开发:从字符设备到I2C传感器驱动实战 本文将系统梳理Linux驱动开发的核心知识与实战流程,从基础概念到项目实践,带你完整掌握Linux驱动开发的关键技术。我们将从字符设备驱动框架讲起,深入设备树配置原理…...
正则表达式(Regular Expression,简称 Regex)
一、5w2h(七问法)分析正则表达式 是的,5W2H 完全可以应用于研究 正则表达式(Regular Expressions)。通过回答 5W2H 的七个问题,我们可以全面理解正则表达式的定义、用途、使用方法、适用场景等,…...
Superset 问题
和nginx结合使用,如果不是配置到根路径,会比较麻烦,我试了很多种方法,也就 这个 靠谱点,不过,我最后还是选择的部署在根路径,先探索一番再说默认不能选择mysql数据库,需要安装mysql客…...
JMeter脚本录制(火狐)
录制前准备: 电脑: 1、将JMeter证书导入,(bin目录下有一个证书,需要安装这个证书到电脑中) 2、按winr,输入certmgr.msc,打开证书,点击下一步,输入JMeter证书…...
基于SpringBoot的“高校社团管理系统”的设计与实现(源码+数据库+文档+PPT)
基于SpringBoot的“高校社团管理系统”的设计与实现(源码数据库文档PPT) 开发语言:Java 数据库:MySQL 技术:SpringBoot 工具:IDEA/Ecilpse、Navicat、Maven 系统展示 总体功能结构图 局部E-R图 系统首页页面 用户…...
Maven/Gradle的讲解
一、为什么需要构建工具? 在理解 Maven/Gradle 之前,先明确它们解决的问题: 依赖管理:项目中可能需要引入第三方库(如 Spring、JUnit 等),手动下载和管理这些库的版本非常麻烦。标准化构建流程:编译代码、运行测试、打包成 JAR/WAR 文件等步骤需要自动…...
C# Winform 入门(3)之尺寸同比例缩放
放大前 放大后 1.定义当前窗体的宽度和高度 private float x;//定义当前窗体的宽度private float y;//定义当前窗台的高度 2.接收当前窗体的尺寸大小 x this.Width;//存储原始宽度ythis.Height;//存储原始高度setTag(this);//为控件设置 Tag 属性 3.声明方法,获…...
infinityfree最新免费建站详细教程_无需备案_5G空间_无限流量_免费域名_免费SSL
一、明确目标—是否要使用 1.为什么选择InfinityFree? 对于初学者、学生或只是想尝试网站搭建的个人用户来说,InfinityFree提供了一个绝佳的免费解决方案。这个国外免费的虚拟主机服务提供: 5GB存储空间 - 足以存放个人博客、作品集或小型…...
打造高效英文单词记忆系统:基于Python的实现与分析
在当今全球化的世界中,掌握一门外语已成为必不可少的技能。对于许多学习者来说,记忆大量的英文单词是一个漫长而艰难的过程。为了提高学习效率,我们开发了一个基于Python的英文单词记忆系统。这个系统结合了数据管理、复习计划、学习统计和测试练习等多个模块,旨在为用户提…...
node_modules\deasync: Command failed.
运行:“yarn install” 时报错 PS D:\WebPro\hainan-mini-program> yarn install yarn install v1.22.19 [1/4] Resolving packages... [2/4] Fetching packages... [3/4] Linking dependencies... warning " > babel-loader8.2.2" has un…...
