Peter算法小课堂—简单建模(4)

2023-12-18 21:52

本文主要是介绍Peter算法小课堂—简单建模(4),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

太戈编程1655题

一条直线上,你安排了n个哨兵站岗放哨,编号从1到n。其中i号哨兵的坐标位置是x[i]。不会有哨兵站在相同的位置。作为指挥官,你需要知道3个信息:

1.从左到右,每个哨兵的坐标依次是几?

2.从左到右,每个哨兵依次是几号哨兵?

3.哨兵编号从1到n,每个哨兵依次站在从左到右的第几个?

离散化

什么是离散化呢?数据离散化处理_哔哩哔哩_bilibili

给出一列数字,在有些情况下,这些数字的值的绝对大小并不重要,而相对大小很重要。例如,对一个班级学生的成绩进行排名,此时不关心成绩的绝对值,只需要输出排名,如分数为{95,50,72,21},排名为{1,3,2,4}。

“离散化”就是用数字的相对值替代它们的绝对值。离散化是一种数据处理的技巧,它把分布广而稀疏的数据转换为密集分布,从而能让算法更快速、更省空间的处理。步骤:1.排序 2.离散化 3.归位

离散化手工编码:

#include <bits/stdc++.h>
using namespace std;
const int N=500010;
struct data{int val;int id;
}olda[N];
int newa[N];
bool cmp(data x,data y){return x.val<y.val;
}
int main(){int n;cin>>n;for(int i=1;i<=n;i++){cin>>olda[i].val;olda[i].id=i;}sort(olda+1,olda+1+n,cmp);for(int i=1;i<=n;i++){newa[olda[i].id]=i;}for(int i=1;i<=n;i++) cout<<newa[i];return 0;
}

那么,回到1655,这题应该怎么做呢?

#include <bits/stdc++.h>
using namespace std;
const int N=100009;
int rk[N];
struct guard{//结构体int x,id;
};
guard g[N];
bool cmp(const guard&u,const guard&v){//排序return u.x<v.x;
}
int main()
{freopen("guard.in","r",stdin);freopen("guard.out","w",stdout);int n;cin>>n;	 for(int i=1;i<=n;i++) cin>>g[i].x;for(int i=1;i<=n;i++) g[i].id=i;//学号赋值sort(g+1,g+1+n,cmp);for(int i=1;i<=n;i++) rk[g[i].id]=i;for(int i=1;i<=n-1;i++) cout<<g[i].x<<" ";cout<<g[n].x<<endl;    for(int i=1;i<=n-1;i++) cout<<g[i].id<<" ";cout<<g[n].id<<endl;    for(int i=1;i<=n-1;i++) cout<<rk[i]<<" ";    cout<<rk[n]<<endl;return 0;
}

太戈编程56题

某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米。我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置;数轴上的每个整数点,即0,1,2,……,L,都种有一棵树 由于马路上有一些区域要用来建地铁。这些区域用它们在数轴上的起始点和终止点表示。已知任一区域的起始点和终止点的坐标都是整数,区域之间可能有重合的部分。现在要把这些区域中的树(包括区域端点处的两棵树)移走。你的任务是计算将这些树都移走后,马路上还有多少棵树

差分

cin>>l>>m;
for(int i=1;i<=m;i++){cin>>a>>b;if(a>b) swap(a,b);a++;b++;//确保都为正整数d[a]++;d[b+1]--;
}

 那么,第5行我为什么敢无缘无故+1呢?这都是缓冲格的帮助。

然后呢?

#include <bits/stdc++.h>
using namespace std;
const int N=1000009;
int l,m,a,b,s[N],d[N];
int main(){freopen("tree.in","r",stdin);freopen("tree.out","w",stdout);cin>>l>>m;for(int i=1;i<=m;i++){cin>>a>>b;if(a>b) swap(a,b);a++;b++;d[a]++;d[b+1]--;}int ans=l+1;for(int i=1;i<=l+1;i++){s[i]=s[i-1]+d[i];if(s[i]) ans--;}cout<<ans<<endl;return 0;
}

但是……如果303题怎么办呢?

太戈编程303题

#include <bits/stdc++.h>
using namespace std;
const int M=1000000009;
struct pnt{int x,tag;
}p[M];
bool cmp(const int&a,const int&b){if(p[a].x<p[b].x) return 1;if(p[a].x>p[b].x) return 0;if(p[a].tag<p[b].tag) return 1;return 0;
}
int main(){int l,m;cin>>l>>m;for(int i=1;i<=m;i++){int a,b;cin>>a>>b;if(a>b) swap(a,b);a++;b++;p[i].x=a;p[i].tag=1;p[i+m].x=b+1;p[i+m].tag=-1;}for(int i=1;i<=2*m;i++) id[i]=i;sort(id+1,id+1+2*m,cmp);int ans=l+1,pre=0;for(int i=1;i<=2*m;i++){if(s[i-1]) ans-=p[id[i]].x-pre;pre=p[id[i]].x;s[i]=s[i-1]+p[id[i]].tag;}cout<<ans<<endl;
}

希望这些对大家有用,三连必回

这篇关于Peter算法小课堂—简单建模(4)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/509882

相关文章

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

redis群集简单部署过程

《redis群集简单部署过程》文章介绍了Redis,一个高性能的键值存储系统,其支持多种数据结构和命令,它还讨论了Redis的服务器端架构、数据存储和获取、协议和命令、高可用性方案、缓存机制以及监控和... 目录Redis介绍1. 基本概念2. 服务器端3. 存储和获取数据4. 协议和命令5. 高可用性6.

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

利用Python编写一个简单的聊天机器人

《利用Python编写一个简单的聊天机器人》这篇文章主要为大家详细介绍了如何利用Python编写一个简单的聊天机器人,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 使用 python 编写一个简单的聊天机器人可以从最基础的逻辑开始,然后逐步加入更复杂的功能。这里我们将先实现一个简单的

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

使用IntelliJ IDEA创建简单的Java Web项目完整步骤

《使用IntelliJIDEA创建简单的JavaWeb项目完整步骤》:本文主要介绍如何使用IntelliJIDEA创建一个简单的JavaWeb项目,实现登录、注册和查看用户列表功能,使用Se... 目录前置准备项目功能实现步骤1. 创建项目2. 配置 Tomcat3. 项目文件结构4. 创建数据库和表5.

使用PyQt5编写一个简单的取色器

《使用PyQt5编写一个简单的取色器》:本文主要介绍PyQt5搭建的一个取色器,一共写了两款应用,一款使用快捷键捕获鼠标附近图像的RGB和16进制颜色编码,一款跟随鼠标刷新图像的RGB和16... 目录取色器1取色器2PyQt5搭建的一个取色器,一共写了两款应用,一款使用快捷键捕获鼠标附近图像的RGB和16

四种简单方法 轻松进入电脑主板 BIOS 或 UEFI 固件设置

《四种简单方法轻松进入电脑主板BIOS或UEFI固件设置》设置BIOS/UEFI是计算机维护和管理中的一项重要任务,它允许用户配置计算机的启动选项、硬件设置和其他关键参数,该怎么进入呢?下面... 随着计算机技术的发展,大多数主流 PC 和笔记本已经从传统 BIOS 转向了 UEFI 固件。很多时候,我们也

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核