C++.备考知识点
C++备考知识点
- 1. 循环结构与等差数列求和
- 1.1 逐天累加实现方法
- 1.2 等差数列求和公式优化
- 2.1 数字转字符串方法
- 2.2 首尾字符交换实现
- 2.3 去除前导零技巧
- 3.1 异或运算基本性质
- 3.2 找出出现奇数次的数
- 问题分析
- 示例代码
- 输出结果
- 扩展应用
- 4.1 字符位移量计算
- 问题分析
- 示例代码
- 输出结果
- 扩展应用
- 4.2 步骤奇偶性判断
- 问题分析
- 示例代码
- 输出结果
- 扩展应用
- 4.3 模26处理循环移位
- 问题分析
- 示例代码
- 输出结果
- 扩展应用
- 5.1 取模运算原理
- 特点
- 应用场景
- 示例代码
- 扩展应用
- 5.2 4 % 12 的计算过程
- 示例代码
- 输出结果
- 扩展应用
- 6.1 转义字符的作用
- 常见的转义字符
- 转义字符的应用场景
- 示例代码
- 输出结果
- 6.2 char a[] = "hello\nworld" 的输出分析
- 示例代码
- 输出结果
- 分析
- 扩展应用
- 7.1 二进制转十进制方法
- 手动计算方法
- 使用C++标准库函数
- 输出结果
- 扩展应用
- 7.2 十六进制转十进制方法
- 手动计算方法
- 使用C++标准库函数
- 输出结果
- 扩展应用
- 7.3 二进制与十六进制加法运算
- 示例计算
- 使用C++实现
- 输出结果
- 扩展应用
- 8.1 布尔代数基本规则
- 8.2 选项 D 的化简过程
- 问题描述
- 化简过程
- 示例代码
- 输出结果
- 分析
1. 循环结构与等差数列求和
1.1 逐天累加实现方法
逐天累加是一种常见的循环结构应用,用于计算累计值。在C++中,可以通过for
循环或while
循环实现。例如,计算每天阅读的页数,直到总页数超过或等于n
,代码如下:
int total_pages = 0;
int daily_pages = 1; // 每天阅读的页数
int n = 100; // 目标总页数while (total_pages < n) {total_pages += daily_pages;daily_pages++; // 每天阅读的页数递增
}
这种方法简单直观,但效率较低,尤其是当n
较大时,循环次数会很多。
1.2 等差数列求和公式优化
等差数列求和公式可以显著优化逐天累加的过程。等差数列的求和公式为:
[
S_n = \frac{n}{2} \times (a_1 + a_n)
]
其中,n
是项数,a_1
是首项,a_n
是末项。对于逐天累加问题,首项a_1
为1,末项a_n
为n
,项数n
可以通过公式求解:
[
n = \sqrt{2 \times \text{总页数}}
]
然后使用求和公式计算总页数,代码如下:
#include <cmath>
int total_pages = 100; // 目标总页数
int n = static_cast<int>(std::sqrt(2 * total_pages)); // 项数
int sum = n * (n + 1) / 2; // 等差数列求和公式if (sum < total_pages) {n++;sum = n * (n + 1) / 2;
}
这种方法通过数学公式减少了循环次数,提高了计算效率。# 2. 字符串操作与前导零处理
2.1 数字转字符串方法
在C++中,将数字转换为字符串有多种方法,每种方法都有其适用场景和优缺点。
-
使用
std::to_string
函数:这是最简单直接的方法,适用于所有基本数据类型(如int
、double
等)。例如:int num = 123; std::string str = std::to_string(num);
这种方法简单易用,但可能会引入不必要的字符(如浮点数的尾部零),需要额外处理。
-
使用
std::ostringstream
:这种方法更灵活,可以处理复杂的格式化需求。例如:std::ostringstream oss; oss << 123; std::string str = oss.str();
这种方法可以方便地将多个不同类型的数据拼接成字符串,但性能略逊于
std::to_string
。 -
使用
sprintf
函数:这是一种C语言风格的函数,可以将格式化的数据写入字符数组。例如:char buffer[10]; sprintf(buffer, "%d", 123); std::string str(buffer);
这种方法性能较高,但需要手动管理缓冲区大小,容易出错。
2.2 首尾字符交换实现
交换字符串的首尾字符是字符串操作中的一个常见需求,可以通过以下步骤实现:
- 获取字符串的首尾字符:通过索引访问字符串的第一个字符和最后一个字符。
- 交换字符:使用临时变量或直接交换字符。
- 更新字符串:将交换后的字符重新赋值给字符串。
示例代码如下:
std::string str = "hello";
if (str.length() > 1) {char temp = str[0];str[0] = str[str.length() - 1];str[str.length() - 1] = temp;
}
这种方法简单直观,但需要注意字符串长度小于2的情况,避免访问无效内存。
2.3 去除前导零技巧
去除字符串中的前导零是一个常见的字符串处理问题,可以通过以下方法实现:
-
使用
std::string::find_first_not_of
方法:找到第一个非零字符的位置,然后截取字符串。例如:std::string str = "00123"; size_t pos = str.find_first_not_of('0'); if (pos != std::string::npos) {str = str.substr(pos); } else {str = "0"; // 如果全是零,返回"0" }
这种方法简洁高效,适用于大多数情况。
-
手动遍历字符串:逐个检查字符,直到找到第一个非零字符,然后截取字符串。例如:
std::string str = "00123"; size_t pos = 0; while (pos < str.length() && str[pos] == '0') {pos++; } if (pos == str.length()) {str = "0"; // 如果全是零,返回"0" } else {str = str.substr(pos); }
这种方法虽然稍显繁琐,但可以更好地控制处理过程。
-
使用
std::stringstream
:将字符串转换为数字,再转换回字符串,自动去除前导零。例如:std::string str = "00123"; std::stringstream ss; ss << std::stoi(
相关文章:
C++.备考知识点
C++备考知识点 1. 循环结构与等差数列求和1.1 逐天累加实现方法1.2 等差数列求和公式优化2.1 数字转字符串方法2.2 首尾字符交换实现2.3 去除前导零技巧3.1 异或运算基本性质3.2 找出出现奇数次的数问题分析示例代码输出结果扩展应用4.1 字符位移量计算问题分析示例代码输出结果…...

SQLMesh 模型管理指南:从创建到验证的全流程解析
本文全面介绍SQLMesh这一现代化数据转换工具的核心功能,重点讲解模型创建、编辑、验证和删除的全生命周期管理方法。通过具体示例和最佳实践,帮助数据工程师掌握SQLMesh的高效工作流程,包括增量模型配置、变更影响评估、安全回滚机制等关键操…...

HarmonyOS AVPlayer 音频播放器
鸿蒙文档中心:使用AVPlayer播放视频(ArkTS)文档中心https://developer.huawei.com/consumer/cn/doc/harmonyos-guides/video-playback 这张图描述的是 HarmonyOS AVPlayer 音频播放器的状态流转过程,展示了 AVPlayer 在不同状态之间的切换条件和关键操作…...

⭐️白嫖的阿里云认证⭐️ 第二弹【课时1:提示词(Prompt)技巧】for 「大模型Clouder认证:利用大模型提升内容生产能力」
「大模型Clouder认证:利用大模型提升内容生产能力」这个认证目前在阿里云认证中心还是免费的,简单几步就可以申请考试,有两次的免费考试机会。而且,这个课程中的内容对于所有普通用户来说都非常实用,课程整体长度也就3节课,非常快速就能学完。心动不如行动,赶紧开始吧!…...

Filament引擎(一) ——渲染框架设计
filament是谷歌开源的一个基于物理渲染(PBR)的轻量级、高性能的实时渲染框架,其框架架构设计并不复杂,后端RHI的设计也比较简单。重点其实在于项目中材质、光照模型背后的方程式和理论,以及对它们的实现。相关的信息,可以参考官方…...

c++从入门到精通(六)--特殊工具与技术-完结篇
文章目录 特殊工具与技术-完结篇控制内存分配运行时类型识别成员指针嵌套类局部类固有的不可抑制特性位域volatile限定符链接指示 extern "C" 特殊工具与技术-完结篇 控制内存分配 重载new和delete: 如果应用程序希望控制内存分配的过程,…...
JDK 1.8 全解析:从核心特性到企业实战的深度实践
引言 JDK 1.8 作为 Java 生态发展史上的里程碑版本,自 2014 年发布以来,凭借 Lambda 表达式、Stream API、新日期时间 API 三大核心特性,彻底重塑了 Java 编程范式。本文结合 Oracle 官方文档、蚂蚁集团、京东零售等企业级实战案例ÿ…...

MCP实战:在扣子空间用扣子工作流MCP,一句话生成儿童故事rap视频
扣子最近迎来重要更新,支持将扣子工作流一键发布成MCP,在扣子空间里使用。 这个功能非常有用,因为我有很多业务工作流是在扣子平台上做的,两者打通之后,就可以在扣子空间里直接通过对话方式调用扣子工作流了࿰…...
分布式微服务系统架构第134集:笔记1运维服务器经验,高并发,大数据量系统
加群联系作者vx:xiaoda0423 仓库地址:https://webvueblog.github.io/JavaPlusDoc/ https://1024bat.cn/ https://github.com/webVueBlog/fastapi_plus https://webvueblog.github.io/JavaPlusDoc/ ✅ 一、查看端口是否被占用的常用命令 1️⃣ lsof 命令&…...
【SSL证书系列】客户端如何验证https网站服务器发的证书是否由受信任的根证书签发机构签发
客户端验证HTTPS网站证书是否由受信任的根证书颁发机构(CA)签发,是一个多步骤的过程,涉及证书链验证、信任锚(Trust Anchor)检查、域名匹配和吊销状态验证等。以下是详细的验证流程: 1. 证书链的…...

SpringBoot基础项目搭建
资料链接:https://download.csdn.net/download/ly1h1/90855288?spm1001.2014.3001.5501 1.准备工作 1.1 安装IntelliJ IDEA 2023.3.4 (Ultimate Edition) 1.2 采用apache-maven-3.6.3 1.2.1 maven配置文件设置 1.2.2 IDEA配置maven 1.3 JDK采用17版本 2.手动创建…...
Rust 学习笔记:关于 HashMap 的练习题
Rust 学习笔记:关于 HashMap 的练习题 Rust 学习笔记:关于 HashMap 的练习题以下代码能否通过编译?若能,输出是?以下代码能否通过编译?若能,输出是? Rust 学习笔记:关于 …...
C语言-8.数组
8.1数组 8.1.1初试数组 如何写一个程序计算用户输入的数字的平均数? #include<stdio.h> int main() {int digit;//输入要求平均数的数字double sum=0;//记录输入数字的和int count=0;//记录输入数字的个数printf("请输入一组数字,用来求平均数,以-1结束\n&quo…...
Kotlin Android单元测试MockK指南
目录 MockK 简介环境配置基础用法高级用法Android 特有场景最佳实践 1. MockK 简介 MockK 是一个专为 Kotlin 设计的 Mocking 框架,支持协程、扩展函数、对象声明(object)等 Kotlin 特性。相比 Mockito,它提供更自然的 Kotlin A…...
C# lock
在C#中,lock关键字用于确保当一个线程位于给定实例的代码块中时,其他线程无法访问同一实例的该代码块。这是一种简单的同步机制,用来防止多个线程同时访问共享资源或执行需要独占访问的代码段(临界区),从而…...
《算法导论(第4版)》阅读笔记:p83-p85
《算法导论(第4版)》学习第 18 天,p83-p85 总结,总计 3 页。 一、技术总结 1. Strassen algorithm(施特拉森算法) 2.矩阵 (1)矩阵表示法 If we wish to refer to matrices without specifically writing out all their entries, we will use upperc…...
Go 后端中双 token 的实现模板
下面是一个典型的 Go 后端双 Token 认证机制 实现模板,使用 Gin 框架 JWT Redis,结构清晰、可拓展,适合实战开发。 项目结构建议 /utils├── jwt.go // Access & Refresh token 的生成和解析├── claims.go // 从请求…...

【拥抱AI】Deer-Flow字节跳动开源的多智能体深度研究框架
最近发现一款可以对标甚至可能超越GPT-Researcher的AI深度研究应用,Deer-Flow(Deep Exploration and Efficient Research Flow)作为字节跳动近期开源的重量级项目,正以其模块化、灵活性和人机协同能力引发广泛关注。该项目基于 La…...
第六天——贪心算法——字符串分隔
1. 题目 给定一个字符串 s,我们需要将其划分为尽可能多的部分,使得同一字母最多出现在一个部分中。 例如:字符串 "ababcc" 可以划分为 ["abab", "cc"],但要避免 ["aba", "bcc&quo…...
Python 条件语句详解
条件语句是编程中用于控制程序流程的基本结构,Python 提供了几种条件语句来实现不同的逻辑判断。 1. if 语句 最基本的条件语句形式: if 条件:# 条件为真时执行的代码块示例: age 18 if age > 18:print("你已经成年了")2. …...

前端获取用户的公网 IP 地址
可以使用免费的免费的公共服务网站 一:https://www.ipify.org/ 获取 JSON 格式的 IP 地址 // 旧地址不好使 // https://api.ipify.org/?formatjson // 新地址 https://api64.ipify.org/?formatjson 二:https://ipinfo.io/ https://ipinfo.io/ 三&a…...
在Maven中替换文件内容的插件和方法
在Maven中替换文件内容的插件和方法 Maven提供了几种方式来替换文件内容,以下是常用的插件和方法: 1. maven-replacer-plugin (推荐) 这是专门用于文件内容替换的插件,功能强大且灵活。 基本配置 <plugin><groupId>com.goog…...
符合Python风格的对象(再谈向量类)
再谈向量类 为了说明用于生成对象表示形式的众多方法,我们将使用一个 Vector2d 类,它与第 1 章中的类似。这一节和接下来的几节会不断实 现这个类。我们期望 Vector2d 实例具有的基本行为如示例 9-1 所示。 示例 9-1 Vector2d 实例有多种表示形式 &g…...

云电竞服务器 工作原理
云电竞服务器工作原理详解 一、核心架构原理 虚拟化资源池 通过 KVM/VMware 等虚拟化技术将物理服务器(含NVIDIA GPU集群)抽象为可动态分配的算力资源池,每个用户独享独立虚拟机实例,实现硬件资源的按需分配与隔离运行。 …...

【数据结构】线性表--队列
【数据结构】线性表--队列 一.什么是队列二.队列的实现1.队列结构定义:2.队列初始化函数:3.队列销毁函数:4.入队列函数(尾插):5.出队列函数(头删):6.取队头元素ÿ…...

[Vue3]语法变动
Vue3的语法相对比Vue2有不少改变,这篇讲一下基础语法在Vue3里的形式。 创建Vue对象 在脚手架项目中,index.html等资源不再编写代码,只作为一个容器。所有的页面代码都在.vue相关文件中进行编写,由main.js引入各个.vue文件渲染出页…...

Ubuntu服务器开启SNMP服务 监控系统配置指南 -优雅草星云智控简易化操作
Ubuntu服务器开启SNMP服务 & 监控系统配置指南 -优雅草星云智控简易化操作 一、Ubuntu服务器开启SNMP服务 步骤1:安装SNMP服务 sudo apt update sudo apt install snmp snmpd snmp-mibs-downloader -y 步骤2:配置SNMP(编辑配置文件&am…...

linux本地部署ollama+deepseek过程
1.Tags ollama/ollama GitHub 选择一个版本下载,我下的是0.5.12 2.tar解压该文件 3.尝试启动ollama ollama serve 4.查看ollama的版本 ollama -v 5.创建一个系统用户 ollama,不允许登录 shell,拥有一个主目录,并且用…...

从零开始实现大语言模型(十五):并行计算与分布式机器学习
1. 前言 并行计算与分布式机器学习是一种使用多机多卡加速大规模深度神经网络训练过程,以减少训练时间的方法。在工业界的训练大语言模型实践中,通常会使用并行计算与分布式机器学习方法来减少训练大语言模型所需的钟表时间。 本文介绍PyTorch中的一种…...

OpenCV进阶操作:指纹验证、识别
文章目录 前言一、指纹验证1、什么是指纹验证2、流程步骤 二、使用步骤(案例)三、指纹识别(案例)1、这是我们要识别的指纹库2、这是待识别的指纹图3、代码4、结果 总结 前言 指纹识别作为生物识别领域的核心技术之一,…...