【CF1445C】Divison 题解
题意简介
给出两个正整数 p 和 q,要求一个最大的 x 使 p 可被 x 整除,而 q 不可被 x 整除。
其中,\(1 \leq p \leq 10^{18} ; 2 \leq q \leq 10^9\)。
思路分析
对于 \(p\mod q \neq 0\) 的情形,显然 x 最大为 p。
至于 \(p \equiv 0 \mod q\) 的情形,可以这样考虑:
首先,我们不难发现 p 必然包含 q 的所有质因数,且 p 质因数分解后每个质因数的指数必定大于等于 q 的。
现在,我们希望 \(x \mod q \neq 0\) 。要求 x 最大,所以我们希望这个 x 可以尽可能地接近 p。
我们记:
\(p = A_1^{d_1} \times A_2^{d_2} \times ... \times A_n^{d_n} \times R\)
\(q = A_1^{c_1} \times A_2^{c_2} \times ... \times A_n^{c_n}\)
显然地,要使 x 尽可能大,我们只需要通过除去某个数,把 p 的某个质因数的指数 \(d_i\) 调到恰好比 \(c_i\) 小就行了。
所以,我们只需要对 q 做质因数分解,顺便求出 \(c_i,d_i\) 。
然后枚举每个质因数,找到最小的 \(A_i^{d_i-c_1+1}\) ,答案就是 p 除以它了。
代码库
#include <cstdio>
#include <cstring>
typedef long long ll;
const int N=1e5;
ll a[N],cc,cq[N],cp[N],aq[N],ap[N];
int main(){
ll t; scanf("%lld",&t);
while(t--){
ll p,q,p1,q1; scanf("%lld%lld",&p,&q);
if(p%q!=0){
printf("%lld\n",p);
continue;
}
p1=p; q1=q; cc=0;
for(int i=2;i*i<=q;i++){
if(q1%i==0){
//记得初始化
a[++cc]=i; cq[cc]=cp[cc]=0; ap[cc]=aq[cc]=1;
while(q1%i==0) q1/=i,cq[cc]++,aq[cc]*=i;
while(p1%i==0) p1/=i,cp[cc]++,ap[cc]*=i;
}
}
//不要忘了这一步
if(q1>1){
a[++cc]=q1;
cq[cc]=cp[cc]=0; ap[cc]=aq[cc]=1;
while(q1%a[cc]==0) q1/=a[cc],cq[cc]++,aq[cc]*=a[cc];
while(p1%a[cc]==0) p1/=a[cc],cp[cc]++,ap[cc]*=a[cc];
}
ll minn=1e18;
for(int i=1;i<=cc;i++){
if(ap[i]/(aq[i]/a[i])<minn) minn=ap[i]/(aq[i]/a[i]);
}
printf("%lld\n",p/minn);
}
return 0;
}
【CF1445C】Divison 题解的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
随机推荐
- python下正则表达式的随笔记录
使用了下正则的表达式: 目的:取出字符串中{}中的内容 最后使用的正则表达式为 {(.*?)} 先看 .*? : 首先 . 是用来匹配字符串,但是只能匹配一次. 所以加上 * ,可以让 ...
- 【小白学PyTorch】16 TF2读取图片的方法
[新闻]:机器学习炼丹术的粉丝的人工智能交流群已经建立,目前有目标检测.医学图像.NLP等多个学术交流分群和水群唠嗑的总群,欢迎大家加炼丹兄为好友,加入炼丹协会.微信:cyx645016617. 参考 ...
- python排序算法总结和实现
------------------希尔排序------------- 一直没搞懂希尔排序怎么搞得 def Shell_sort(L): step = len(L)/2 while step > ...
- MATLAB中conv2的详细用法 (以及【matlab知识补充】conv2、filter2、imfilter函数原理)
转载: 1.https://blog.csdn.net/jinv5/article/details/52874880 2.https://blog.csdn.net/majinlei121/artic ...
- matlab中repmat函数的用法
转载:https://blog.csdn.net/facetosea1/article/details/83573859 B = repmat(A,m,n)B = repmat(A,[m n])B = ...
- 初学者的Android移植:在Debian上建立一个稳定的构建环境
介绍 通过在chrooted环境中设置开发环境,避免依赖冲突和沙箱您的Android开发从您的Debian GNU/Linux系统.这是为通配符类别准备的,因为从源代码构建Android似乎没有在其他 ...
- 自定义Antd Pro 默认元素
概要 通用元素 修改的方式 主页面 标签上的图标 logo 和 系统名称 footer 的配置 loading 页面 最终效果 概要 使用 Antd Pro 来开发前端项目时, 生成的项目模板中, 一 ...
- 添加Google网络地图功能
在MeteoInfo中添加了Google网络地图功能.打开MeteoInfo软件,选中图层管理区的一个Map Frame(New Map Frame),点击鼠标右键,在弹出菜单中点击Add Web L ...
- Navicat Premium 15破解
https://pan.baidu.com/s/1bJ1BJUcL6cFd4StB5Qn_hQ 提取码:1314 拿走,不谢!!!
- 解决React前端在开发环境的跨域问题
在前后端分离的分布式架构中,跨域是一道无法绕过去的门槛,众所周知,生产环境上解决跨域最便捷的方式是使用Nginx来处理,那么,在本地开发环境又该如何处理呢? React框架里处理跨域问题,可以使用ht ...