【基础算法】模拟算法
文章目录
- 算法简介
- 1. 多项式输出
- 解题思路
- 代码实现
- 2. 蛇形方阵
- 解题思路
- 代码实现
- 3. 字符串的展开
- 解题思路
- 代码实现
算法简介
模拟,顾名思义,就是题目让你做什么你就做什么,考察的是将思路转化成代码的代码能力。 这类题一般较为简单,属于竞赛里面的签到题(但是,万事无绝对,也有可能会出现让人非常难受的模拟题),我们在学习语法阶段接触的题,大多数都属于模拟题。
下面我们通过几道 OJ 练习题来感受一下。
1. 多项式输出
【题目链接】
[P1067 NOIP 2009 普及组] 多项式输出 - 洛谷
【题目描述】
一元 n n n 次多项式可用如下的表达式表示:
f ( x ) = a n x n + a n − 1 x n − 1 + ⋯ + a 1 x + a 0 , a n ≠ 0 f(x)=a_nx^n+a_{n-1}x^{n-1}+\cdots +a_1x+a_0,a_n\ne 0 f(x)=anxn+an−1xn−1+⋯+a1x+a0,an=0
其中, a i x i a_ix^i aixi 称为 i i i 次项, a i a_i ai 称为 i i i 次项的系数。给出一个一元多项式各项的次数和系数,请按照如下规定的格式要求输出该多项式:
多项式中自变量为 x x x,从左到右按照次数递减顺序给出多项式。
多项式中只包含系数不为 0 0 0 的项。
如果多项式 n n n 次项系数为正,则多项式开头不出
+
号,如果多项式 n n n 次项系数为负,则多项式以-
号开头。对于不是最高次的项,以
+
号或者-
号连接此项与前一项,分别表示此项系数为正或者系数为负。紧跟一个正整数,表示此项系数的绝对值(如果一个高于 0 0 0 次的项,其系数的绝对值为 1 1 1,则无需输出 1 1 1)。如果 x x x 的指数大于 1 1 1,则接下来紧跟的指数部分的形式为“ x b x^b xb”,其中 b b b 为 x x x 的指数;如果 x x x 的指数为 1 1 1,则接下来紧跟的指数部分形式为 x x x;如果 x x x 的指数为 0 0 0,则仅需输出系数即可。多项式中,多项式的开头、结尾不含多余的空格。
【输入格式】
输入共有 2 2 2 行
第一行 1 1 1 个整数, n n n,表示一元多项式的次数。
第二行有 n + 1 n+1 n+1 个整数,其中第 i i i 个整数表示第 n − i + 1 n-i+1 n−i+1 次项的系数,每两个整数之间用空格隔开。
【输出格式】
输出共 1 1 1 行,按题目所述格式输出多项式。
【示例一】
输入
5 100 -1 1 -3 0 10
输出
100x^5-x^4+x^3-3x^2+10
【示例二】
输入
3 -50 0 0 1
输出
-50x^3+1
【说明/提示】
NOIP 2009 普及组 第一题
对于100%数据, 0 ≤ n ≤ 100 0 \le n \le 100 0≤n≤100,$-100 \le 系数 系数 系数 \le 100$
解题思路
注意到多项式的每一项都是由符号、系数以及字母 x x x 带上相应的次数构成的。所以我们不妨从这三个角度出发去模拟,构建出每一项。
-
符号
- 负数:直接输出
-
- 正数:
- 是第 n n n 项,不输出
+
- 其余情况,直接输出
+
- 是第 n n n 项,不输出
- 负数:直接输出
-
系数(先取绝对值)
- 不是 1 1 1,直接输出这个数字
- 是 1 1 1
- 如果是末项,需要输出
- 不是末项,不需要输出
-
次数
- 次数为 0 0 0,什么都不输出
- 次数为 1 1 1,输出 x x x 即可
- 其他情况,输出
x^
+ 对应的次数
代码实现
#include<iostream>
#include<cmath>using namespace std;int main()
{int n; cin >> n;for(int i = n; i >= 0; --i){int k; cin >> k;if(k == 0) continue;// 1.处理符号if(k < 0) cout << '-';else{if(i != n) cout << '+';}// 2.处理系数k = abs(k);if(k != 1 || (k == 1 && i == 0)) cout << k;// 3.处理次数if(i == 1) cout << 'x';if(i > 1) cout << "x^" << i;}return 0;
}
2. 蛇形方阵
【题目链接】
P5731 【深基5.习6】蛇形方阵 - 洛谷
【题目描述】
给出一个不大于 9 9 9 的正整数 n n n,输出 n × n n\times n n×n
的蛇形方阵。从左上角填上 1 1 1 开始,顺时针方向依次填入数字,如同样例所示。注意每个数字有都会占用 3 3 3 个字符,前面使用空格补齐。
【输入格式】
输入一个正整数 n n n,含义如题所述。
【输出格式】
输出符合题目要求的蛇形矩阵。
【示例一】
输入
4
输出
1 2 3 4 12 13 14 5 11 16 15 6 10 9 8 7
【说明/提示】
数据保证, 1 ≤ n ≤ 9 1 \leq n \leq 9 1≤n≤9。
解题思路
由于我们填数的时候是按照右下左上四个方向依次填入的,因此像这样的问题,我们有一个较为通用的方法就是使用方向向量。
首先我们需要定义一个二位数组(矩阵),这里我们以向下为 x x x 轴正方向,向右为 y y y 轴建立平面直角坐标系。那么向右走就对应 y y y +1
, x x x 不变;向下走就对应 x x x +1
,y
不变;向左向上同理。这样一来我们就可以定义出方向向量如下:
int dx[] = {0, 1, 0, -1};
int dy[] = {1, 0, -1, 0};
4 个位置从左往右依次对应右上左下 4 个方向。比如当我们需要向右走时,我们只需:
x += dx[0], y += dx[0];
定义好了方向向量之后,我们就开始填数。思路很简单,朝着一个方向填数,直到越界或者遇到已经填过的位置。如果越界或者遇到已经填过的位置,那么就更新方向向量再朝另一个方向填数。总共填 n * n
个数字,填完之后遍历数组输出即可。
代码实现
#include<iostream>using namespace std;#define N 15
int arr[N][N];int dx[] = {0, 1, 0, -1}; // 方向向量
int dy[] = {1, 0, -1, 0};int main()
{int n; cin >> n;int x = 1, y = 1; // 起始位置int pos = 0;int cnt = 1;while(cnt <= n * n){arr[x][y] = cnt;// 要填的下一个位置int a = x + dx[pos];int b = y + dy[pos];if(a < 1 || a > n || b < 1 || b > n || arr[a][b]) // 如果这个位置不能填{pos = (pos + 1) % 4; // 换方向a = x + dx[pos];b = y + dy[pos];}x = a, y = b;++cnt;}for(int i = 1; i <= n; ++i){for(int j = 1; j <= n; ++j){printf("%3d", arr[i][j]); // 注意输出格式}puts("");}return 0;
}
3. 字符串的展开
【题目链接】
[P1098 NOIP 2007 提高组] 字符串的展开 - 洛谷
【题目描述】
在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中,含有类似于
d-h
或者4-8
的字串,我们就把它当作一种简写,输出时,用连续递增的字母或数字串替代其中的减号,即,将上面两个子串分别输出为defgh
和45678
。在本题中,我们通过增加一些参数的设置,使字符串的展开更为灵活。具体约定如下:(1) 遇到下面的情况需要做字符串的展开:在输入的字符串中,出现了减号
-
,减号两侧同为小写字母或同为数字,且按照ASCII
码的顺序,减号右边的字符严格大于左边的字符。(2) 参数 p 1 p_1 p1:展开方式。 p 1 = 1 p_1=1 p1=1 时,对于字母子串,填充小写字母; p 1 = 2 p_1=2 p1=2 时,对于字母子串,填充大写字母。这两种情况下数字子串的填充方式相同。 p 1 = 3 p_1=3 p1=3 时,不论是字母子串还是数字字串,都用与要填充的字母个数相同的星号
*
来填充。(3) 参数 p 2 p_2 p2:填充字符的重复个数。 p 2 = k p_2=k p2=k 表示同一个字符要连续填充 k k k 个。例如,当 p 2 = 3 p_2=3 p2=3 时,子串
d-h
应扩展为deeefffgggh
。减号两边的字符不变。(4) 参数 p 3 p_3 p3:是否改为逆序: p 3 = 1 p_3=1 p3=1 表示维持原来顺序, p 3 = 2 p_3=2 p3=2 表示采用逆序输出,注意这时候仍然不包括减号两端的字符。例如当 p 1 = 1 p_1=1 p1=1、 p 2 = 2 p_2=2 p2=2、 p 3 = 2 p_3=2 p3=2 时,子串
d-h
应扩展为dggffeeh
。(5) 如果减号右边的字符恰好是左边字符的后继,只删除中间的减号,例如:
d-e
应输出为de
,3-4
应输出为34
。如果减号右边的字符按照ASCII
码的顺序小于或等于左边字符,输出时,要保留中间的减号,例如:d-d
应输出为d-d
,3-1
应输出为3-1
。
【输入格式】
共两行。
第 1 1 1 行为用空格隔开的 3 3 3 个正整数,依次表示参数 p 1 , p 2 , p 3 p_1,p_2,p_3 p1,p2,p3。
第 2 2 2 行为一行字符串,仅由数字、小写字母和减号
-
组成。行首和行末均无空格。
【输出格式】
共一行,为展开后的字符串。
【示例一】
输入
1 2 1 abcs-w1234-9s-4zz
输出
abcsttuuvvw1234556677889s-4zz
【示例二】
输入
2 3 2 a-d-d
输出
aCCCBBBd-d
【说明/提示】
40 % 40\% 40% 的数据满足:字符串长度不超过 5 5 5。
100 % 100\% 100% 的数据满足: 1 ≤ p 1 ≤ 3 , 1 ≤ p 2 ≤ 8 , 1 ≤ p 3 ≤ 2 1 \le p_1 \le 3,1 \le p_2 \le 8,1 \le p_3 \le 2 1≤p1≤3,1≤p2≤8,1≤p3≤2。字符串长度不超过 100 100 100。
NOIP 2007 提高第二题
解题思路
这道题的要求都在题干中说清楚了,重点就是转化为代码,考察的是代码能力。
依次遍历字符串,遇到除 -
以外的其他字符,不做特殊处理。遇到 -
,就按照题目要求做处理即可。
代码实现
#include <iostream>
#include <algorithm>using namespace std;int p1, p2, p3, n;
string s; // 读入的字符串
string ret; // 最终展开后的字符串// 判断是否是数字字符
bool isdig(char ch)
{return ch >= '0' && ch <= '9';
}// 判断是否是⼩写字⺟
bool islet(char ch)
{return ch >= 'a' && ch <= 'z';
}// 把 [left, right] 之间的字符展开
// left, right 这两个字符是不做处理的
void add(char left, char right)
{string t;// 遍历中间的字符 for (char ch = left + 1; ch < right; ch++){char tmp = ch;// 处理 p1 if (p1 == 2 && islet(tmp)) tmp -= 32; // ⼩写变⼤写else if (p1 == 3) tmp = '*'; // 变成星号 // 处理 p2 for (int i = 0; i < p2; i++){t += tmp;}}// 处理 p3 if (p3 == 2) reverse(t.begin(), t.end());ret += t;
}int main()
{cin >> p1 >> p2 >> p3 >> s;n = s.size();for (int i = 0; i < n; i++){char ch = s[i];if (s[i] != '-' || i == 0 || i == n - 1) ret += ch;else{char left = s[i - 1], right = s[i + 1];// 判断是否展开 if (isdig(left) && isdig(right) && right > left ||islet(left) && islet(right) && right > left){// 展开 add(left, right);}else{ret += ch;}}}cout << ret << endl;return 0;
}
相关文章:
【基础算法】模拟算法
文章目录 算法简介1. 多项式输出解题思路代码实现 2. 蛇形方阵解题思路代码实现 3. 字符串的展开解题思路代码实现 算法简介 模拟,顾名思义,就是题目让你做什么你就做什么,考察的是将思路转化成代码的代码能力。 这类题一般较为简单…...
项目 react+taro 编写的微信 小程序,什么命令,可以减少console的显示
在 Taro 项目中,为了减少 console 的显示(例如 console.log、console.info 等),可以通过配置 terser-webpack-plugin 来移除生产环境中的 console 调用。 配置步骤: 修改 index.js 文件 在 mini.webpackChain 中添加 …...
Android 开发 Kotlin 全局大喇叭与广播机制
在 Android 开发中,广播机制就像一个神通广大的 “消息快递员”,承担着在不同组件间传递信息的重任。Kotlin 语言的简洁优雅更使其在广播机制的应用中大放异彩。今天,就让我们一同深入探索 Android 开发中 Kotlin 全局大喇叭与广播机制的奥秘…...

微信小程序关于截图、录屏拦截
1.安卓 安卓: 在需要禁止的页面添加 onShow() {if (wx.setVisualEffectOnCapture) {wx.setVisualEffectOnCapture({visualEffect: hidden,complete: function(res) {}})}},// 页面隐藏和销毁时需要释放防截屏录屏设置onHide() {if (wx.setVisualEffectOnCapture) {w…...

基于51单片机的音乐盒键盘演奏proteus仿真
地址: https://pan.baidu.com/s/1tZCAxQQ7cvyzBfztQpk0UA 提取码:1234 仿真图: 芯片/模块的特点: AT89C52/AT89C51简介: AT89C51 是一款常用的 8 位单片机,由 Atmel 公司(现已被 Microchip 收…...

【unity游戏开发——编辑器扩展】EditorUtility编辑器工具类实现如文件操作、进度条、弹窗等操作
注意:考虑到编辑器扩展的内容比较多,我将编辑器扩展的内容分开,并全部整合放在【unity游戏开发——编辑器扩展】专栏里,感兴趣的小伙伴可以前往逐一查看学习。 文章目录 前言一、确认弹窗1、确认弹窗1.1 主要API1.2 示例 2、三按钮…...
WPF中自定义消息弹窗
WPF 自定义消息弹窗开发笔记 一、XAML 布局设计 文件:MessageInfo.xaml <Window x:Class"AutoFeed.UserControls.MessageInfo"xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x"http://schemas.microsoft.…...

Android之ListView
1:简单列表(ArrayAdapter) 1:运行的结果: 2:首先在MyListView里面创建一个按钮,点击的时候进行跳转。 这里让我吃惊的是,Button里面可以直接设置onClick .java里面的方法。 也即是点击这个按钮之后就会去…...
查服务器信息 常用的一些命令 =^^ =
本文主要记录Linux系统的各项指令工具 目录 一、系统基础信息 1. 操作系统与内核信息 2. 主机名与 IP 二、CPU 和内存使用 1. CPU 与内存占用情况(动态监控) 2. 只看 CPU 与内存用量 三、磁盘与文件系统 1. 磁盘空间使用情况 2. 磁盘 inode 使用…...
PS裁剪后像素未删除?5步解决“删除裁剪像素”失效问题
在Photoshop中遇到“删除裁剪的像素”功能失效的问题时,可能涉及软件设置、版本兼容性或操作流程错误。以下是具体原因和解决方案: 一、常见原因分析 未正确勾选“删除裁剪的像素”选项 在裁剪工具属性栏中,需手动勾选该选项才能永久删除裁剪…...

《Spring Cloud Gateway 快速入门:从路由到自定义 Filter 的完整教程》
1.网关介绍 在前面的学习中,我们通过Eureka和Nacos解决了辅助注册,使用Spring Cloud LoadBalance解决了负载均衡的问题,使用OpenFeign解决了远程调用的问题。 但是当前的所有微服务的接口都是直接对外暴露的,外部是可以直接访问…...

第3节 Node.js 创建第一个应用
Node.js 非常强大,只需动手写几行代码就可以构建出整个HTTP服务器。事实上,我们的Web应用以及对应的Web服务器基本上是一样的。 在我们创建Node.js第一个"Hello, World!"应用前,让我们先了解下Node.js应用是由哪几部分组成的&…...

我们来学mysql -- “数据备份还原”sh脚本
数据备份&还原 说明执行db_backup_cover.sh脚本 说明 环境准备:来源数据库(服务器A);目标数据库(服务器B)dbInfo.sh脚本记录基本信息 来源库、目标库的ip、port及执行路径 # MySQL 客户端和 mysqldump 的路径 MYSQL_CLIENT"/work/oracle/mysql…...
mkcert实现本地https
1.下载 mkcert 从 mkcert GitHub 发布页 下载适用于 Windows 的版本(如 mkcert-v1.4.4-windows-amd64.exe)。 安装 mkcert 以管理员身份运行命令提示符(CMD),执行以下命令安装并信任本地 CAÿ…...

【排序算法】快速排序详解--附详细流程代码
快速排序算法 介绍 快速排序(Quick Sort)是一种高效的分治排序算法,由英国计算机科学家 Tony Hoare 于 1960 年提出。它是实际应用中最常用的排序算法之一。快速排序的基本思想是:选择一个"基准"(pivot&am…...
Kerberos面试内容整理-会话密钥的协商与使用
在 Kerberos 认证过程中,**会话密钥(Session Key)**扮演着关键角色。会话密钥是由 KDC 临时生成并分发给通信双方用于当前会话的对称加密密钥。与用户密码这类长期密钥不同,会话密钥的生命周期很短,仅在特定的认证会话或服务访问期间有效。这种设计大幅提升了安全性:长期…...

解决各个系统报错TDengine:no taos in java.library.path问题
windows 系统解决办法 在本地上安装一个TD的Windows客户端,注意安装的客户端版本一定要和服务端TD版本完全一致。(或者将 C:\TDengine\driver\taos.dll 拷贝到 C:\Windows\System32\ 目录下) 客户端各个历史版本下载链接:TDengin…...

java helloWord java程序运行机制 用idea创建一个java项目 标识符 关键字 数据类型 字节
HelloWord public class Hello{public static void main(String[] args) {System.out.print("Hello,World!");} }java程序运行机制 用idea创建一个java项目 建立一个空项目 新建一个module 注释 标识符 关键字 标识符注意点 数据类型 public class Demo02 {public st…...
LVS-NAT 负载均衡群集
目录 简介 一、LVS 与群集技术基础 1.1 群集技术概述 1.2 负载均衡群集的分层结构 1.3 负载均衡工作模式 二、LVS 虚拟服务器核心组件与配置 2.1 LVS 内核模块与管理工具 2.2 负载调度算法解析 2.3 ipvsadm 管理工具实战 三、NFS 共享存储服务配置 3.1 NFS 服务基础…...

免费文本转语音工具体验:祈风TTS使用
简介:语音生成的另一种方式 现在很多人通过视频记录生活,表达观点。拍摄剪辑不难,配音成了常见难题。部分人对自己的声音不够自信,也有人在特定场景下不便出声。文本转语音工具可以成为解决方案。 常见的TTS(Text To…...
ipv6与p2p的关系
在PCDN(P2P内容分发网络)领域,IPv6与PCDN盒子的关系紧密且相互影响,主要体现在以下几个方面: 一、IPv6的部署推动PCDN盒子普及 地址资源充足 IPv6采用128位地址,解决了IPv4地址枯竭的问题,为PC…...

JS和TS的区别
JavaScript 与 TypeScript 的主要区别和特性对比 1. 基础定义 JavaScript 是一种动态、弱类型的编程语言,广泛应用于前端开发以及通过 Node.js 扩展到后端开发。TypeScript 则是 JavaScript 的超集,它在 JavaScript 的基础上添加了静态类型系统和其他增…...

Python实现P-PSO优化算法优化BP神经网络分类模型项目实战
说明:这是一个机器学习实战项目(附带数据代码文档),如需数据代码文档可以直接到文章最后关注获取。 1.项目背景 随着人工智能技术的快速发展,神经网络在分类任务中展现了强大的性能。BP(Back Propagation&…...

Linux --进度条小程序更新
这里使用随机数来模拟下载量,来实现一个下载进度更新的小程序 main.c 的代码,其中downlod这个函数使用的是函数指针,如果有多个进度条函数可以传入进行多样化的格式下载显示,还需要传入一个下载总量,每次"下载以…...
JVM——回顾:JVM的起源、特性与系统构成
引入 在当今数字化时代,Java语言及其运行环境Java虚拟机(JVM)在软件开发领域占据着举足轻重的地位。从大型企业级应用到各类移动应用,JVM凭借其独特的特性和强大的功能,为开发者提供了高效且稳定的运行环境。 JVM的起…...
实现MPC钱包
多方计算(MPC,Multiparty Computation)钱包是一种利用密码学技术实现的加密货币钱包,它允许多个参与者共同生成和管理钱包的私钥,而无需将私钥暴露给任何单个参与者。这种钱包具有高度的安全性和隐私性。实现一个 MPC …...
每日算法刷题Day19 5.31:leetcode二分答案3道题,用时1h
6. 475.供暖器(中等,学习check函数双指针思想) 475. 供暖器 - 力扣(LeetCode) 思想 1.冬季已经来临。 你的任务是设计一个有固定加热半径的供暖器向所有房屋供暖。在加热器的加热半径范围内的每个房屋都可以获得供暖。现在,给出…...
【线上故障排查】缓存热点Key导致Redis性能下降的排查与优化
一、高频面试题 什么是缓存热点Key?它会对Redis性能产生哪些影响? 缓存热点Key是指在某段时间内,被大量请求访问的缓存Key。由于Redis是单线程模型,大量针对热点Key的请求会导致该线程长时间处于忙碌状态,其他请求只能排队等待处理,从而使Redis整体响应延迟增加,吞吐量下…...

关于镜像如何装进虚拟机
本篇文章为感谢小仙猪老师特别编写 本篇文章仅以Ubuntu为例 目录 创建虚拟机 汉化 如果没有China选项 检查网络 创建虚拟机 第一步,创建虚拟机 因为,第一个选项是会把虚拟机的文件放在c盘因此,这里博主选择自定义,然后下一…...
CPU特权级别:硬件与软件协同构建系统安全的基石
在计算机系统的底层架构中,用户模式(User Mode)与内核模式(Kernel Mode)的划分是保障系统安全与稳定的核心机制。这一机制的实现既依赖于CPU硬件的特权级别设计,也离不开操作系统的精细化管理。本文将从硬件…...