洛谷题单 Part 2.4 分治

news/2024/5/19 0:08:24/文章来源:https://blog.csdn.net/dhdhdhx/article/details/127019452

分治 即分而治之 将大问题化解为小问题逐一求解
这种题没有固定的模板 只有分治的思想 所以在做题的时候应当多想如何将一个大问题化解成若干个子问题进行求解
直接上题了

P1226 【模板】快速幂||取余运算

非常经典的分治问题
常规算法求aba^babO(b)O(b)O(b)的时间复杂度 我们运用分治的思想
观察到如果2∣b,2|b,2∣b那么ab=(a2)b/2a^b=(a^2)^{b/2}ab=(a2)b/2这样就降低了一半的幂次 时间复杂度降到了O(log2b)O(log_2b)O(log2b)
所以 当bbb是偶数时,ab=(a2)b/2a^b=(a^2)^{b/2}ab=(a2)b/2
bbb时奇数时,ab=(a2)b/2∗aa^b=(a^2)^{b/2}*aab=(a2)b/2a
上代码

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
ll quickpow(ll x, ll y, ll mod){ll re=1LL;while(y!=0){if(y%2==1)re=re*x%mod;x=x*x%mod,y=y/2;}return re;
}
ll n,m,p;
int main(){cin>>n>>m>>p;printf("%lld^%lld mod %lld=%lld\n",n,m,p,quickpow(n,m,p));
}

我们用位运算简化一下 就会得到非常好看的快速幂

(我觉得还挺好看的

P1010 [NOIP1998 普及组] 幂次方

一个递归题 没想到居然一遍过了
对于一个数 从他的二进制最高位开始判断 如果有1,1,1,那么就输出2(2(2(位数),),)位数再进行操作 依次递归
对于2、1、02、1、0210要单独判断 如果是000直接输出 1/21/21/2

#include<bits/stdc++.h>
using namespace std;
void op(int x){if(x==0){putchar(48);return ;}bool flag=0;for(int i=18;i>=2;i--){if(x&(1<<i)){if(!flag)flag=1;else putchar('+');printf("2(");op(i);printf(")");}}if(x&(1<<1)){if(!flag)flag=1;else putchar('+');putchar('2');}if(x&1){if(!flag)flag=1;else putchar('+');printf("2(0)");}
}
int main(){int x;cin>>x;op(x);puts("");
}

P1429 平面最近点对(加强版)

传送门
加强版的加强版
利用分治的思想 每次将整个区间分为两部分求解 分别求出左右两部分的最小值 再将两部分合并求最小值
细节部分 首先区间缩小到只剩两个点时显然结果为这两个点的最小值
其次将一个区间的左右两部分求解出来时 对于中间的点 我们找到距离midmidmid左右两侧距离最小值的点 对于这些点暴力求解更新最小值 显然这些点不会有太多 因此这个暴力的时间复杂度是常数级别的
上代码↓

#include<bits/stdc++.h>
#define N int(2e6+10)
#define INF ((1LL<<62)-1+(1LL<<62))
#define ll long long
using namespace std;
inline void read(ll &x){ll s=0,w=1;char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')w=-1;ch=getchar();}while(ch>='0'&&ch<='9'){s=(s<<3)+(s<<1)+(ch&15);ch=getchar();}x=s*w;
}
struct node{ll x,y;
}p[N],op[N];
bool cmp(node a, node b){if(a.x!=b.x)return a.x<b.x;else return a.y<b.y;
}
bool opcmp(node a, node b){if(a.y!=b.y)return a.y<b.y;else return a.x<b.x;
}
ll dis(node i, node j){return (i.x-j.x)*(i.x-j.x)+(i.y-j.y)*(i.y-j.y);
}
ll n,px,py,mn=INF,mx,pnt;
ll merge(ll l, ll r){if(l>=r)return INF;if(r-l==1)return dis(p[l],p[r]);ll mid=l+r>>1;ll le=merge(l,mid),ri=merge(mid+1,r);mn=(min(le,ri),mn),pnt=0;for(ll i=l;i<=r;i++)if((p[mid].x-p[i].x)*(p[mid].x-p[i].x)<mn)op[++pnt]=p[i];sort(op+1,op+1+pnt,opcmp);for(ll i=1;i<=pnt;i++){for(ll j=i+1;j<=pnt;j++){if((op[i].y-op[j].y)*(op[i].y-op[j].y)>=mn)break;if(dis(op[i],op[j])<mn)mn=dis(op[i],op[j]);}}return mn;
}
int main(){read(n);for(ll i=1;i<=n;i++)read(p[i].x),read(p[i].y);sort(p+1,p+1+n,cmp);printf("%.4lf\n",sqrt(merge(1,n)));
}

P3612 [USACO17JAN]Secret Cow Code S

传送门
题意大概是给你一个字符串 对这个字符串进行以下操作
先将最后一位复制到后面 再把除了最后一位剩下的字符串复制到后面 然后就变成了一个新的字符串
以此类推 一直复制下去 给你一个位数 求这个位数上的字符是啥
刚开始还以为是一直回文 后来才发现是直接把前面的字符整体复制过来 那就简单了
对于每个位数 找到上一次复制操作时所对应的位数就行了

#include<bits/stdc++.h>
using namespace std;
char str[50];
long long n;
int main(){scanf("%s%lld",str,&n);int len=strlen(str);int now=62;while((1LL<<now)>n*2/len)now--;while(now!=0){if(n==(1LL<<now-1)*len+1)n--;else if(n>(1LL<<now-1)*len)n-=(1+(1LL<<now-1)*len);now--;}putchar(str[n-1]);
}

总结

分治算法是算法竞赛中经常用到的算法 非常玄学 当处理大数据无从下手的时候不妨试试分治算法

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_20500.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Mybatis常见查询总结,仅限于初级程序员阅读

情况描述&#xff1a; 本人初次接触Mybatis&#xff0c;然后对于其中的一些基础查询做一些简单总结&#xff0c;一次用来记录他的用法&#xff0c;便于以后查漏补缺。 1、Mybatis中查询特定的列:&#xff08;单列&#xff09; 如果查询指定列为Long类型&#xff0c;那么在re…

游戏合作伙伴专题:BreederDAO 与 Affyn一起重构现实生活

BreederDAO 团队很宣布与 Affyn 建立了新的合作关系&#xff0c;Affyn 是一家位于新加坡的公司&#xff0c;开发了基于地理位置的增强现实移动游戏。 移动元宇宙 Affyn 团队由来自 EA、任天堂、迪士尼和星巴克等顶级游戏、娱乐和生活方式公司的资深员工组成。他们洞悉了目前边玩…

html5网页设计作业代码 大学生校园网站制作 学校官网制作html

&#x1f329;️ 精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; &#x1f482; 作者主页: 【进入主页—&#x1f680;获取更多源码】 &#x1f393; web前端期末大作业&#xff1a; 【&#x1f4da;HTML5网页期末作业 (1000套…

性能大PK count(*)、count(1)和count(列)

最近的工作中&#xff0c;我听到组内两名研发同学在交流数据统计性能的时候&#xff0c;聊到了以下内容&#xff1a; 数据统计你怎么能用 count() 统计数据呢&#xff0c;count() 太慢了&#xff0c;要是把数据库搞垮了那不就完了么&#xff0c;赶紧改用 count(1)&#xff0c;这…

基于Gossip的online server

在游戏服务端架构中online server,有些也叫center server。 主要承载以下功能:存储玩家的在线信息,处理上线和下线消息。 转发消息给特定玩家。online server在架构图中的位置online server集群内部架构图,以3个实例为例:特点:svr之间相互连接,采用Gossip协议通信。 各s…

MCMS 审计之路

MCMS 是 J2EE 系统&#xff0c;完整开源的Java CMS&#xff0c;基于SpringBoot 2架构&#xff0c;前端基于vue、element ui。为开发者提供上百套免费模板,同时提供适用的插件&#xff08;文章、商城、微信、论坛、会员、评论、支付、积分、工作流、任务调度等...&#xff09;&a…

大学网课查题系统

大学网课查题系统 本平台优点&#xff1a; 多题库查题、独立后台、响应速度快、全网平台可查、功能最全&#xff01; 1.想要给自己的公众号获得查题接口&#xff0c;只需要两步&#xff01; 2.题库&#xff1a; 查题校园题库&#xff1a;查题校园题库后台&#xff08;点击跳…

VB6开发 用户控件OCX

VB6 中创建一个主窗体工程后,再添加一个 ActiveX用户控件工程 在用户控件窗体中可以添加 文本框和按钮的控件 属性Public strUrl As String方法发送消息 Public Sub WebSocketSendMsg(ByVal SendMsg As String) On Error GoTo ErrTrapDim sMsg As StringsMsg = msgInput.TextC…

公众号网课答案系统搭建

公众号网课答案系统搭建 本平台优点&#xff1a; 多题库查题、独立后台、响应速度快、全网平台可查、功能最全&#xff01; 1.想要给自己的公众号获得查题接口&#xff0c;只需要两步&#xff01; 2.题库&#xff1a; 查题校园题库&#xff1a;查题校园题库后台&#xff08;…

Java I/O流和反射机制

文章目录File类操作文件或目录属性认识Java的流使用字节流读写文本文件使用字节流类FileInputStream读文本文件使用字节流类FileOutputStream写文本文件使用字符流读写文本文件使用字符流类BufferedReader和FileReader读文本文件使用字符流类BufferedWrite和FileWrite写文本文件…

公众号订阅通知

洛塔服务号回复010获取代码。 功能说明 公众号订阅通知这个功能&#xff0c;微信本来打算替代掉模板消息和一次性订阅的&#xff0c;最后也没替代掉&#xff0c;成为单独的一个功能。 个人感觉和一次性订阅是没有太大区别的&#xff0c;只不过增加了一个长期订阅&#xff0c;…

2022测试工作太难找,怎样才能优先获得面试机会?

软件测试岗位前期门槛低&#xff0c;但是想要拿到高薪真没那么简单。工作 2-3 年薪资还在原地打转的同学&#xff0c;都大有人在。 根据我对招聘需求的研究&#xff0c;以及跟拿到高薪的同学交流发现&#xff0c;他们普遍被要求&#xff1a; 1、学历 在学历方面&#xff0c;…

SAP 顾问攻略笔记之寄售业务

寄售业务处理 供应商寄售&#xff08;Vendor Consignment&#xff09;是企业与供应商签订协议&#xff0c;要求供应商将货物送达企业仓库&#xff0c;由企业进行保管&#xff0c;并自由分配使用&#xff0c;此时不发生物权转移&#xff0c;企业实际消耗或者转为自有库存时&…

SQL抽象语法树及改写场景应用

1 背景 我们平时会写各种各样或简单或复杂的sql语句&#xff0c;提交后就会得到我们想要的结果集。比如sql语句&#xff0c;”select * from t_user where user_id > 10;”&#xff0c;意在从表t_user中筛选出user_id大于10的所有记录。你有没有想过从一条sql到一个结果集&…

Linux_Bash_Shell_索引数组和关联数组及稀疏数组

1. 索引数组一、什么是索引数组? 所谓索引数组就是普通数组,以整数作为数组元素的索引下标。二、实例。 备注: (a)使用-a选项定义索引数组,使用一对小括号()定义数组中的元素列表。 (b)索引数组使用整数作为数组元素下标。备注: (a)使用@和*作为数组下标,表示获取所有元素…

Abp项目(.net) 部署到服务端IIS 无法正常打开页面运行问题

1.当前项目使用abp开发&#xff0c;框架是.net6.0 版本。项目开发完毕后是按照正常流程发布。因此发布完成后根目录下面会有一个 .exe 后缀可执行的应用程序。 2. 如果直接点击.exe 应用程序&#xff0c;是能正常运行的输出。 3.但是部署到iis 上&#xff0c;就出现如下错误 …

2022华为杯D题问题一详细思路建模和程序

问题一思路 本问题的赛题总共包括两个子问题&#xff0c;需要同学们在满足上述数据依赖、控制依赖、以及各具体子问题的资源约束条件下进行资源排布&#xff0c;并充分考虑各子问题的优化目标&#xff0c;以求最大化芯片资源利用率。 问题1&#xff1a;给定资源约束条件如下&a…

远程桌面控制公司内网电脑修改PPT

微软的PowerPoint&#xff0c;相信是大家最熟悉的软件之一&#xff0c;其在我们工作中的重要性不言而喻。通常情况下&#xff0c;PPT做好后总会有各种各样的改动&#xff0c;如果恰逢自己没在办公室&#xff0c;而PPT又急需修改&#xff08;笔者就曾经碰到过这样尴尬的情况&…

Keras深度学习实战(29)——长短时记忆网络详解与实现

Keras深度学习实战&#xff08;29&#xff09;——长短时记忆网络详解与实现0. 前言1. RNN 的局限性2. LSTM 模型架构详解2.1 LSTM 架构2.2 LSTM 各组成部分与计算流程3. 从零开始实现 LSTM3.1 LSTM 模型实现3.2 验证输出小结系列链接0. 前言 长短时记忆网络 (Long Short Term…

【Linux】部署Jenkins(简介及详细教程【war包部署】)

文章目录Jenkins简介持续集成&#xff08;CI&#xff09;持续集成的效益持续集成的作用持续集成的特点持续交付&#xff08;CD&#xff09;持续部署&#xff08;CD&#xff09;Maven介绍部署Jenkins页面访问操作Jenkins简介 随着软件开发需求及复杂度的不断提高&#xff0c;团队…