当前位置: 首页 > 编程日记 > 正文

AtcoderCodeForces杂题11.6

Preface

NOIP前突然不知道做什么,感觉思维有点僵化,就在vjudge上随便组了6道ABC D+CF Div2 C/D做,发现比赛质量还不错,知识点涉及广,难度有梯度,码量稍小,思维较多. 同时发现vjudge的比赛功能很不错

A. ABC112-D-Partition

难度感觉比NOIP T1简单了些了

首先naiive的想法是枚举这个公约数\(D\),但是发现有\(D*N<=M\)这个约束,算了算发现\(M/N <=1e4\)

于是开心从大到小枚举就好了

太水了

int n,m;
int main(){read(n),read(m);for(ri i=m/n;i>=1;i--){if(m%i==0){printf("%d\n",i);break;}}return 0;
}

B. ABC110-D-Factorization

应该有NOIP T1难度

我先考虑如果这个M是一个质数,那么就有N种可能,稍稍推广一下,如果\(M = P^c\),那么就相当于你有\(N\)个不同的盒子,然后盒子内可以不装东西,求放\(c\)个物品的方案数

这个就是隔板法的经典模型

如果您不知道是什么就看这篇洛谷日报吧:https://www.luogu.org/blog/chengni5673/dang-xiao-qiu-yu-shang-he-zi

于是对于\(M= \prod pi^{ci}\),由于每个\(pi\)是独立的,直接乘法原理相乘就好了

一开始用线性推逆元,不知道怎么回事一直最后一个点WA,最后改成阶乘版本就过了...

int n,m;
int c[maxn],tot=0;
ll fac[maxn],inv_fac[maxn];
ll C(int n,int m){return fac[m]*inv_fac[n]%P*inv_fac[m-n]%P;
}
ll ksm(ll a){ll ans=1;ll c=P-2;while(c){if(c&1)ans=ans*a%P;a=a*a%P;c=c>>1;}return ans%P;
}
int main(){int x,y,M;read(n),read(m);M=m;for(ri i=2;i*i<=M;i++){if(M%i==0){c[++tot]=1;M/=i;while(M%i==0){M/=i;c[tot]++;}}}if(M>1)c[++tot]=1;fac[0]=fac[1]=1;for(ri i=2;i<=size;i++)fac[i]=fac[i-1]*i%P;inv_fac[size]=ksm(fac[size]);for(ri i=size-1;i>=0;i--)inv_fac[i]=inv_fac[i+1]*1ll*(i+1)%P;ll ans=1;for(ri i=1;i<=tot;i++){ans=ans*C(n-1,n+c[i]-1)%P;}printf("%lld\n",ans);return 0;
}

C. ABC106-D-AtcoderExpress2

个人认为应该有NOIPT2难度了(天天爱跑步算了)

第一眼一看裸题啊!求一段区间内有多少个被完全包含的区间.冷静分析之后发现并不会做

从数据结构想到容斥还是毫无思路

然后下午睡了一觉之后一下子就想出个一看就不是正解的方法:我会二维数点!

我们对于询问/给出的区间都用\((l,r)\)表示,那么你看这个这个东西,它是不是像炉石补偿一个平面直角坐标系上的一个点

同时发现询问区间\((l,r)\),实际上就是询问有多少个点\((l_i,r_i)\)满足\(l_i>=l,r_i<=r\)

画一个图发现它其实就是求一个矩形内有多少个点,我们按照二维数点套路搞一波就好了

关于二维数点:https://www.cnblogs.com/Rye-Catcher/p/9823554.html

这里注意排序时的cmp就好了,代码同样短的可怕

int sum[maxn<<3];
int n,m,q;
inline void add(int x,int d){for(;x<=n;x+=x&(-x))sum[x]+=d;return ;}
inline int query(int x){int ans=0;for(;x;x-=x&(-x))ans+=sum[x];return ans;}
struct Pt{int x,y,id;bool operator <(const Pt &rhs)const{return (x==rhs.x)?(y==rhs.y?id<rhs.id:y<rhs.y):x>rhs.x;//注意cmp}
}pt[maxn<<2];
int tot=0,qry[maxn];
int main(){int x,y;read(n),read(m),read(q);for(ri i=1;i<=m;i++){read(x),read(y);pt[++tot]=(Pt){x,y,0};}for(ri i=1;i<=q;i++){read(x),read(y);pt[++tot]=(Pt){x,y,i};}std::sort(pt+1,pt+1+tot);for(ri i=1;i<=tot;i++){//printf("%d %d %d %d\n",i,pt[i].id,pt[i].x,pt[i].y);if(!pt[i].id)add(pt[i].y,1);else qry[pt[i].id]=query(pt[i].y);}for(ri i=1;i<=q;i++)printf("%d\n",qry[i]);return 0;
} 

D.CF-EducationalRound52-C-MakeItEqual

这题应该比T1稍难一点

首先naiive的想法就是按照高度排序一遍后,不断向下拓展,但是发现操作繁琐,而且我的做法是一个错误的想法

然后这时候我看到值域居然只有2e5?!然后我们还是按照一样的思路一路向下拓展,如果不行的话切一刀就好了

代码同样很短

注意判0的情况,太坑了

int h[maxn],n,ans=0;
int sz[maxn],mx=0,mi=inf,mi_id;
ll k,sum=0;
int main(){read(n),read(k);for(ri i=1;i<=n;i++){read(h[i]);mx=max(mx,h[i]);mi=min(mi,h[i]);sz[h[i]]++;}int num=0;if(mx==mi){puts("0");return 0;}for(ri i=mx;i>=mi;i--){sum+=num;if(sum>k){ans++;sum=num;}num+=sz[i];}ans++;//最后无论如何都要切一刀printf("%d\n",ans);return 0;
}

E. CF-Round#485 div.2 D - Fair

这题昨天没想出来,今天看题解发现还挺简单的 雾)

关键还是思维太僵化了

我们可以用BFS求出每个点到某种颜色的最短路,时间复杂度\(O(nk)\)

然后对于每个点都$nth $_ \(element\),求出前s小的颜色距离加起来就好了

const int maxn=100005;
const int inf=0x7fffffff;
int n,m,k,s;
int col[maxn];
vector <int> fc[105];
struct Edge{int ne,to;
}edge[maxn<<1];
int h[maxn],num_edge=1;
inline void add_edge(int f,int to){edge[++num_edge].ne=h[f];edge[num_edge].to=to;h[f]=num_edge;
}
int dis[maxn][105];
inline void bfs(int c){queue <int> q;int u,v;for(ri i=0;i<fc[c].size();i++)q.push(fc[c][i]);while(q.size()){u=q.front();q.pop();for(ri i=h[u];i;i=edge[i].ne){v=edge[i].to;if(dis[v][c]!=inf)continue;dis[v][c]=dis[u][c]+1;q.push(v);}}return ;
}
int main(){int x,y,z;read(n),read(m),read(k),read(s);for(ri i=1;i<=n;i++){read(col[i]);fc[col[i]].push_back(i);for(ri c=1;c<=k;c++){dis[i][c]=inf;}dis[i][col[i]]=0;}for(ri i=1;i<=m;i++){read(x),read(y);add_edge(x,y);add_edge(y,x);}for(ri c=1;c<=k;c++){bfs(c);}int ans=0;for(ri i=1;i<=n;i++){ans=0;nth_element(dis[i]+1,dis[i]+s+1,dis[i]+1+k);for(ri j=1;j<=s;j++)ans+=dis[i][j];printf("%d ",ans);}puts("");return 0;
}

F.

转载于:https://www.cnblogs.com/Rye-Catcher/p/9927941.html

相关文章:

centos下将vim配置为强大的源码阅读器

每日杂事缠身&#xff0c;让自己在不断得烦扰之后终于有了自己的清静时光来熟悉一下我的工具&#xff0c;每次熟悉源码都需要先在windows端改好&#xff0c;拖到linux端&#xff0c;再编译。出现问题&#xff0c;还得重新回到windows端&#xff0c;这个过程太耗费时间。 vim作为…

虚拟机看服务器mac地址,虚拟机修改服务器mac地址吗

虚拟机修改服务器mac地址吗 内容精选换一换本章节指导用户为Windows系统的ECS主机添加域名解析并添加安全组&#xff0c;防止下载Agent安装包与采集监控数据时出现异常。修改ECS的DNS配置有两种方式&#xff1a;Windows图形化界面和管理控制台。您可以根据自己的使用习惯选择其…

条件注释判断浏览器!--[if !IE]!--[if IE]!--[if lt IE 6]!--[if gte IE 6]

条件注释判断浏览器<!--[if !IE]><!--[if IE]><!--[if lt IE 6]><!--[if gte IE 6]> <!--[if !IE]><!--> 除IE外都可识别 <!--<![endif]--><!--[if IE]> 所有的IE可识别 <![endif]--><!--[if IE 6]> 仅IE6可识…

USACO09FEB Fair Shuttle

题目传送门 据说\(NOIp\)前发题解可以\(\mathfrak{RP}\) 因为要尽可能满足更多奶牛&#xff0c;所以按照这种区间贪心题的套路&#xff0c;先按右端点排序&#xff0c;然后依次遍历&#xff0c;能坐车的就让它们坐车&#xff0c;这样一定是最优的。 在贪心的时候&#xff0c;我…

diy高性能存储服务器,diy存储服务器

diy存储服务器 内容精选换一换帮助用户完成专属云服务器备份任务的创建&#xff0c;快速完成服务器数据保护。专属云服务器不支持应用一致性备份。当专属对象存储的容量不足时&#xff0c;会导致专属云服务器备份创建失败。已开通专属对象存储。登录管理控制台。单击&#xff0…

使用内存盘 格式化文件系统以及部署ceph-osd

文章目录创建RAMDISK使用内存盘使用内存盘格式化文件系统使用内存盘部署ceph-osd删除内存盘为了测试内存盘类型的磁盘做ceph osd的io性能&#xff0c;将内存部分空间取出来用作普通物理磁盘(RAMDISK)&#xff0c;并在该磁盘上部署ceph osd支持该操作的系统驱动为brd.koPS &…

iBatis的CRUD操作详细总结

昨天晚上看了一下关于iBatis的一个讲解的视频&#xff0c;讲的和我的这个简单的总结差不多.... 思考了一下还是把主要操作都总结一下吧&#xff0c;当然这里也不是全的&#xff0c;知识简单的CRUD。。。 首先我觉得持久层的操作主要就是这几个&#xff1a; public interface IP…

min聚合函数查询带有额外字段sql|dense_rank()over(partition)|+班级学生成绩最高

oracle爱好者和群snowg的问题 上面的这个&#xff0c;有站点stationid&#xff0c;year&#xff0c;month&#xff0c;day和每天记录的day_tmin字段。现在要求统计处每个stationid下面每月每日的最小day_tmin字段&#xff0c;因为不关注year&#xff0c;所以sql这样写 select …

提升jmeter自身性能

JMeter负载测试时使用GUI界面和较多的收集测试结果的监听器容易造成jmeter的性能瓶颈&#xff0c;远程测试时的控制台尤为明显。提升JMeter负载测试时性能的方法如下&#xff1a; 官方的解决办法&#xff1a;http://jakarta.apache.org/jmeter/usermanual/best-practices.html#…

C++ STL的reserve函数

在阅读ceph源码过程中发现部分C语法还是不够熟悉&#xff0c;特此做一下笔记。 关于STL中的reserve函数的使用 reserve()是为容器预留空间&#xff0c;即为当前容器设定一个空间分配的阈值&#xff0c;但是并不会为容器直接allocate具体的空间&#xff0c;具体空间的分配是在创…

AJAX进行分页

新建数据集&#xff1a;PagingDataSet.xsd SELECT * from ( select id, areaID, area, father,Row_Number() over (order by areaID) rownum FROM dbo.area) t where t.rownum >startRowIndex and t.rownum <endRowIndex在集合中添加两个参数&#xff1a; startRowIndex…

华为服务器引入清空外部配置文件,云服务器还原配置文件

云服务器还原配置文件 内容精选换一换外部镜像文件在从原平台导出前&#xff0c;没有按照“Windows操作系统的镜像文件限制”的要求完成初始化操作&#xff0c;推荐您使用弹性云服务器完成相关配置。流程如图1所示。云服务器的正常运行依赖于XEN Guest OS driver(PV driver)和K…

脚本SFTP定时取Linux服务器文件

为什么80%的码农都做不了架构师&#xff1f;>>> 在工作中尤其是政府机关为了安全方面考虑&#xff0c;通常是不开通服务器与服务器之间FTP服务 如果每天又要巡检服务器&#xff0c;每次都要登录查看某个文件给自己的工作带来很大的不便 这里通过 winscp工具使用S…

使用sigaction处理内核信号

文章目录函数描述函数使用抓取发送信号的进程信息mark一次获取内核信号&#xff0c;并作相应处理的手段linux内核中断机制的一个重要实现就是信号。信号使得内核和用户态的交互更加便捷&#xff0c;这个便捷对开发者来说可以更好的利用系统原生内核来处理信息。《深入理解unix内…

ios share extension 真机不显示_ios企业签名:APPGroups实现App之间数据共享

一、认识App GroupsAppGroup allows data sharing between two different apps or even app and widgets by creating one common shared path (like document directory). Data saved over there can be accessed by any app which is associated with that particular AppGro…

处理 JSON null 和空数组及对象

描述了对 JSON 数据中使用的 null 和空数组及对象的处理。 JSON 数据具有 null 和空数组及对象的概念。此部分说明其中每个概念如何映射到 null 和未设置的数据对象概念。 Null 值 JSON 具有特殊值 null&#xff0c;可以对任何数据类型设置该值&#xff0c;包括数组、对象、数字…

xml file too big to import to wordpress website

xml文件太大无法上传到wordpress 原因&#xff1a;从一个wordpress上导出了自己所有的文章&#xff0c;大概6~7MB&#xff0c;准备导入到本机自建的一个wordpress&#xff0c;不过上传文件有限制&#xff0c;最大2MB。 解决方法&#xff1a; 1. 网上很多关于修改配置文件的…

亚麻 面经_ml

Ds -如何预测一个人会不会在下一个月在Amazon买东西&#xff0c;有什么模型。https://mlwave.com/predicting-repeat-buyers-vowpal-wabbit/https://www.researchgate.net/post/How_can_I_study_the_past_spending_behaviour_of_a_customer_in_a_banking_perspective_and_predi…

ceph bluestore源码分析:C++ 获取线程id

阅读ceph源码过程中需要明确当前操作是由哪个线程发出&#xff0c;此时需要根据线程id来确认线程名称 C获取线程id是通过系统调用来直接获取 函数描述 头文件:<sys/syscall.h> 函数名称:syscall(SYS_gettid) 该函数直接返回了一个pid_t int类型的数字&#xff0c;即为当…

判断两直线段是否相交

转自&#xff1a;http://www.cnblogs.com/shengshouzhaixing/archive/2013/03/17/2964950.html //功能&#xff1a;求点在有向直线左边还是右边 //返回&#xff1a;0共线、1左边、-1右边 int left_right(point a,point b,double x,double y) { d…

led显示屏建设标准_户外LED显示屏3大防护标准_显示屏应对恶劣天气?

户外LED显示屏是现在LED显示屏应用最棺广泛的领域。面积巨大&#xff0c;显示效果震撼。同时为了更好的宣传效果&#xff0c;通常安装余楼顶&#xff0c;道路等空旷无遮挡地带。由于面积大且处于露天状态&#xff0c;LED显示屏面临巨大的环境挑战。经常要面对大风、暴雨、冰雹等…

转载 Sqlerver 计算 MD5

2019独角兽企业重金招聘Python工程师标准>>> 在SQl2005下自带的函数hashbytes() &#xff0c;此函数是微软在SQL SERVER 2005中提供的&#xff0c;可以用来计算一个字符串的 MD5 和 SHA1 值&#xff0c;使用方法如下&#xff1a; --获取123456的MD5加密串 select ha…

vim使用说明

模式 命令 操作 开始 vim 文件路径 打开|新建文件 命令模式 i 切换到输入模式 x 删除当前光标所在处的字符 : 切换到底线命令模式 shiftzz 保存并退出 移动光标的方法 h|← 左 j|↓ 下 k|↑ 上 l|→ 右 [Ctrl] [f] 输入模式下的page down [Ctrl] […

g++编译c++11特性 的.cc文件

写一个.cc文件&#xff0c;其中抱哈std::lock_guard以及std::thread等c11特性&#xff0c;开始使用gcc编译,过程中出现如下问题 gcc test_lock.cc -o test_lock This file requires compiler and library support for the ISO C 2011 standard. This support is currently ex…

联想r720内存频率_联想 IdeaPad14s 2020 轻薄本双十一促销

IT之家11月10日消息 作为一款主打轻薄的笔记本电脑&#xff0c;联想 IdeaPad14s 2020 自推出以来便受到不少办公学习用户的青睐。如今&#xff0c;这款联想 IdeaPad14s 2020 轻薄笔记本已开启双十一促销&#xff0c;搭载第十代酷睿处理器&#xff0c;采用 14 英寸双侧窄边框屏幕…

HDU 1273 漫步森林

比赛的时候是看见人家A得很快&#xff0c;但是一看的时候觉得没什么头绪&#xff0c;画了一个六边形的灵感来了&#xff0c;就YY一下 第一次提交写错了结束条件&#xff0c;之后意淫下公式交上去A了。 用五边形来解释&#xff1a; 1.设有五个点1&#xff0c;2,3,4,5, 2.从1开始…

在请求完成后回调delegate的方法。然而回调时经常遇到这种情况:delegate已经被释放...

最近的项目遇到了网络请求&#xff0c;需要在请求完成后回调delegate的方法。然而回调时经常遇到这种情况&#xff1a;delegate已经被释放&#xff0c;这时调用其方法则会引起crash。 objc的runtime中有两种判断类型的方式比较靠谱&#xff0c;他们可以直接取得任意一个objc_ob…

C++ 学习笔记之——文件操作和文件流

1. 文件的概念 对于用户来说&#xff0c;常用到的文件有两大类&#xff1a;程序文件和数据文件。而根据文件中数据的组织方式&#xff0c;则可以将文件分为 ASCII 文件和二进制文件。 ASCII 文件&#xff0c;又称字符文件或者文本文件&#xff0c;它的每一个字节放一个 ASCII 代…

利用blktrace分析磁盘I/O

原文&#xff1a;https://blog.csdn.net/ygtlovezf/article/details/80528300 blktrace对于分析block I/O是个非常好的工具&#xff0c;本篇文章记录了如何使用blktrace。 blktrace原理 blktrace是对通用块层&#xff08;block layer&#xff09;的I/O跟踪机制&#xff0c;它…

shiro 同时实现url和按钮的拦截_一个“保存”按钮同时存在“增删改”三种操作,该如何去实现?...

一般情况下&#xff0c;对表格中的数据进行“增删改”操作&#xff0c;都是直接操作数据库。现在有些项目因为设计或者优化的缘故&#xff0c;不对表格中的数据进行“增删改”&#xff0c;而是通过最后“保存”按钮的操作&#xff0c;一次性将数据传至服务器&#xff0c;由服务…