当前位置: 首页 > article >正文

【基础算法】模拟算法

文章目录

  • 算法简介
  • 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+an1xn1++a1x+a0,an=0

其中, a i x i a_ix^i aixi 称为 i i i 次项, a i a_i ai 称为 i i i 次项的系数。给出一个一元多项式各项的次数和系数,请按照如下规定的格式要求输出该多项式:

  1. 多项式中自变量为 x x x,从左到右按照次数递减顺序给出多项式。

  2. 多项式中只包含系数不为 0 0 0 的项。

  3. 如果多项式 n n n 次项系数为正,则多项式开头不出 + 号,如果多项式 n n n 次项系数为负,则多项式以 - 号开头。

  4. 对于不是最高次的项,以 + 号或者 - 号连接此项与前一项,分别表示此项系数为正或者系数为负。紧跟一个正整数,表示此项系数的绝对值(如果一个高于 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,则仅需输出系数即可。

  5. 多项式中,多项式的开头、结尾不含多余的空格。

【输入格式】

输入共有 2 2 2

第一行 1 1 1 个整数, n n n,表示一元多项式的次数。

第二行有 n + 1 n+1 n+1 个整数,其中第 i i i 个整数表示第 n − i + 1 n-i+1 ni+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 0n100,$-100 \le 系数 系数 系数 \le 100$


解题思路

注意到多项式的每一项都是由符号系数以及字母 x x x 带上相应的次数构成的。所以我们不妨从这三个角度出发去模拟,构建出每一项。

  • 符号

    • 负数:直接输出 -
    • 正数:
      • 是第 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 1n9


解题思路

由于我们填数的时候是按照右下左上四个方向依次填入的,因此像这样的问题,我们有一个较为通用的方法就是使用方向向量

首先我们需要定义一个二位数组(矩阵),这里我们以向下为 x x x 轴正方向,向右为 y y y 轴建立平面直角坐标系。那么向右走就对应 y y y +1 x x x 不变;向下走就对应 x x x +1y 不变;向左向上同理。这样一来我们就可以定义出方向向量如下:

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 的字串,我们就把它当作一种简写,输出时,用连续递增的字母或数字串替代其中的减号,即,将上面两个子串分别输出为 defgh45678。在本题中,我们通过增加一些参数的设置,使字符串的展开更为灵活。具体约定如下:

(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 应输出为 de3-4 应输出为 34。如果减号右边的字符按照 ASCII 码的顺序小于或等于左边字符,输出时,要保留中间的减号,例如:d-d 应输出为 d-d3-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 1p13,1p28,1p32。字符串长度不超过 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. 字符串的展开解题思路代码实现 算法简介 模拟&#xff0c;顾名思义&#xff0c;就是题目让你做什么你就做什么&#xff0c;考察的是将思路转化成代码的代码能力。 这类题一般较为简单&#xf…...

项目 react+taro 编写的微信 小程序,什么命令,可以减少console的显示

在 Taro 项目中&#xff0c;为了减少 console 的显示&#xff08;例如 console.log、console.info 等&#xff09;&#xff0c;可以通过配置 terser-webpack-plugin 来移除生产环境中的 console 调用。 配置步骤&#xff1a; 修改 index.js 文件 在 mini.webpackChain 中添加 …...

Android 开发 Kotlin 全局大喇叭与广播机制

在 Android 开发中&#xff0c;广播机制就像一个神通广大的 “消息快递员”&#xff0c;承担着在不同组件间传递信息的重任。Kotlin 语言的简洁优雅更使其在广播机制的应用中大放异彩。今天&#xff0c;就让我们一同深入探索 Android 开发中 Kotlin 全局大喇叭与广播机制的奥秘…...

微信小程序关于截图、录屏拦截

1.安卓 安卓&#xff1a; 在需要禁止的页面添加 onShow() {if (wx.setVisualEffectOnCapture) {wx.setVisualEffectOnCapture({visualEffect: hidden,complete: function(res) {}})}},// 页面隐藏和销毁时需要释放防截屏录屏设置onHide() {if (wx.setVisualEffectOnCapture) {w…...

基于51单片机的音乐盒键盘演奏proteus仿真

地址&#xff1a; https://pan.baidu.com/s/1tZCAxQQ7cvyzBfztQpk0UA 提取码&#xff1a;1234 仿真图&#xff1a; 芯片/模块的特点&#xff1a; AT89C52/AT89C51简介&#xff1a; AT89C51 是一款常用的 8 位单片机&#xff0c;由 Atmel 公司&#xff08;现已被 Microchip 收…...

【unity游戏开发——编辑器扩展】EditorUtility编辑器工具类实现如文件操作、进度条、弹窗等操作

注意&#xff1a;考虑到编辑器扩展的内容比较多&#xff0c;我将编辑器扩展的内容分开&#xff0c;并全部整合放在【unity游戏开发——编辑器扩展】专栏里&#xff0c;感兴趣的小伙伴可以前往逐一查看学习。 文章目录 前言一、确认弹窗1、确认弹窗1.1 主要API1.2 示例 2、三按钮…...

WPF中自定义消息弹窗

WPF 自定义消息弹窗开发笔记 一、XAML 布局设计 文件&#xff1a;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&#xff1a;简单列表(ArrayAdapter) 1&#xff1a;运行的结果&#xff1a; 2&#xff1a;首先在MyListView里面创建一个按钮&#xff0c;点击的时候进行跳转。 这里让我吃惊的是&#xff0c;Button里面可以直接设置onClick .java里面的方法。 也即是点击这个按钮之后就会去…...

查服务器信息 常用的一些命令 =^^ =

本文主要记录Linux系统的各项指令工具 目录 一、系统基础信息 1. 操作系统与内核信息 2. 主机名与 IP 二、CPU 和内存使用 1. CPU 与内存占用情况&#xff08;动态监控&#xff09; 2. 只看 CPU 与内存用量 三、磁盘与文件系统 1. 磁盘空间使用情况 2. 磁盘 inode 使用…...

PS裁剪后像素未删除?5步解决“删除裁剪像素”失效问题

在Photoshop中遇到“删除裁剪的像素”功能失效的问题时&#xff0c;可能涉及软件设置、版本兼容性或操作流程错误。以下是具体原因和解决方案&#xff1a; 一、常见原因分析 未正确勾选“删除裁剪的像素”选项 在裁剪工具属性栏中&#xff0c;需手动勾选该选项才能永久删除裁剪…...

《Spring Cloud Gateway 快速入门:从路由到自定义 Filter 的完整教程》​

1.网关介绍 在前面的学习中&#xff0c;我们通过Eureka和Nacos解决了辅助注册&#xff0c;使用Spring Cloud LoadBalance解决了负载均衡的问题&#xff0c;使用OpenFeign解决了远程调用的问题。 但是当前的所有微服务的接口都是直接对外暴露的&#xff0c;外部是可以直接访问…...

第3节 Node.js 创建第一个应用

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

我们来学mysql -- “数据备份还原”sh脚本

数据备份&还原 说明执行db_backup_cover.sh脚本 说明 环境准备&#xff1a;来源数据库(服务器A)&#xff1b;目标数据库(服务器B)dbInfo.sh脚本记录基本信息 来源库、目标库的ip、port及执行路径 # MySQL 客户端和 mysqldump 的路径 MYSQL_CLIENT"/work/oracle/mysql…...

mkcert实现本地https

​​1.下载 mkcert​​ 从 mkcert GitHub 发布页 下载适用于 Windows 的版本&#xff08;如 mkcert-v1.4.4-windows-amd64.exe&#xff09;。 ​​安装 mkcert​​ 以管理员身份运行命令提示符&#xff08;CMD&#xff09;&#xff0c;执行以下命令安装并信任本地 CA&#xff…...

【排序算法】快速排序详解--附详细流程代码

快速排序算法 介绍 快速排序&#xff08;Quick Sort&#xff09;是一种高效的分治排序算法&#xff0c;由英国计算机科学家 Tony Hoare 于 1960 年提出。它是实际应用中最常用的排序算法之一。快速排序的基本思想是&#xff1a;选择一个"基准"&#xff08;pivot&am…...

Kerberos面试内容整理-会话密钥的协商与使用

在 Kerberos 认证过程中,**会话密钥(Session Key)**扮演着关键角色。会话密钥是由 KDC 临时生成并分发给通信双方用于当前会话的对称加密密钥。与用户密码这类长期密钥不同,会话密钥的生命周期很短,仅在特定的认证会话或服务访问期间有效。这种设计大幅提升了安全性:长期…...

解决各个系统报错TDengine:no taos in java.library.path问题

windows 系统解决办法 在本地上安装一个TD的Windows客户端&#xff0c;注意安装的客户端版本一定要和服务端TD版本完全一致。&#xff08;或者将 C:\TDengine\driver\taos.dll 拷贝到 C:\Windows\System32\ 目录下&#xff09; 客户端各个历史版本下载链接&#xff1a;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使用

简介&#xff1a;语音生成的另一种方式 现在很多人通过视频记录生活&#xff0c;表达观点。拍摄剪辑不难&#xff0c;配音成了常见难题。部分人对自己的声音不够自信&#xff0c;也有人在特定场景下不便出声。文本转语音工具可以成为解决方案。 常见的TTS&#xff08;Text To…...

ipv6与p2p的关系

在PCDN&#xff08;P2P内容分发网络&#xff09;领域&#xff0c;IPv6与PCDN盒子的关系紧密且相互影响&#xff0c;主要体现在以下几个方面&#xff1a; 一、IPv6的部署推动PCDN盒子普及 地址资源充足 IPv6采用128位地址&#xff0c;解决了IPv4地址枯竭的问题&#xff0c;为PC…...

JS和TS的区别

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

Python实现P-PSO优化算法优化BP神经网络分类模型项目实战

说明&#xff1a;这是一个机器学习实战项目&#xff08;附带数据代码文档&#xff09;&#xff0c;如需数据代码文档可以直接到文章最后关注获取。 1.项目背景 随着人工智能技术的快速发展&#xff0c;神经网络在分类任务中展现了强大的性能。BP&#xff08;Back Propagation&…...

Linux --进度条小程序更新

这里使用随机数来模拟下载量&#xff0c;来实现一个下载进度更新的小程序 main.c 的代码&#xff0c;其中downlod这个函数使用的是函数指针&#xff0c;如果有多个进度条函数可以传入进行多样化的格式下载显示&#xff0c;还需要传入一个下载总量&#xff0c;每次"下载以…...

JVM——回顾:JVM的起源、特性与系统构成

引入 在当今数字化时代&#xff0c;Java语言及其运行环境Java虚拟机&#xff08;JVM&#xff09;在软件开发领域占据着举足轻重的地位。从大型企业级应用到各类移动应用&#xff0c;JVM凭借其独特的特性和强大的功能&#xff0c;为开发者提供了高效且稳定的运行环境。 JVM的起…...

实现MPC钱包

多方计算&#xff08;MPC&#xff0c;Multiparty Computation&#xff09;钱包是一种利用密码学技术实现的加密货币钱包&#xff0c;它允许多个参与者共同生成和管理钱包的私钥&#xff0c;而无需将私钥暴露给任何单个参与者。这种钱包具有高度的安全性和隐私性。实现一个 MPC …...

每日算法刷题Day19 5.31:leetcode二分答案3道题,用时1h

6. 475.供暖器(中等&#xff0c;学习check函数双指针思想) 475. 供暖器 - 力扣&#xff08;LeetCode&#xff09; 思想 1.冬季已经来临。 你的任务是设计一个有固定加热半径的供暖器向所有房屋供暖。在加热器的加热半径范围内的每个房屋都可以获得供暖。现在&#xff0c;给出…...

【线上故障排查】缓存热点Key导致Redis性能下降的排查与优化

一、高频面试题 什么是缓存热点Key?它会对Redis性能产生哪些影响? 缓存热点Key是指在某段时间内,被大量请求访问的缓存Key。由于Redis是单线程模型,大量针对热点Key的请求会导致该线程长时间处于忙碌状态,其他请求只能排队等待处理,从而使Redis整体响应延迟增加,吞吐量下…...

关于镜像如何装进虚拟机

本篇文章为感谢小仙猪老师特别编写 本篇文章仅以Ubuntu为例 目录 创建虚拟机 汉化 如果没有China选项 检查网络 创建虚拟机 第一步&#xff0c;创建虚拟机 因为&#xff0c;第一个选项是会把虚拟机的文件放在c盘因此&#xff0c;这里博主选择自定义&#xff0c;然后下一…...

CPU特权级别:硬件与软件协同构建系统安全的基石

在计算机系统的底层架构中&#xff0c;用户模式&#xff08;User Mode&#xff09;与内核模式&#xff08;Kernel Mode&#xff09;的划分是保障系统安全与稳定的核心机制。这一机制的实现既依赖于CPU硬件的特权级别设计&#xff0c;也离不开操作系统的精细化管理。本文将从硬件…...