原题链接

题意简介

给出两个正整数 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 题解的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

随机推荐

  1. Elasticsearch数据库 | Elasticsearch-7.5.0应用基础实战

    Elasticsearch 是一个可用于分布式以及符合RESTful 风格的搜索和数据分析引擎.-- Elastic Stack 官网 关于Elasticsearch的"爱恨情仇" ...

  2. Python练习题 032:Project Euler 004:最大的回文积

    本题来自 Project Euler 第4题:https://projecteuler.net/problem=4 # Project Euler: Problem 4: Largest palind ...

  3. 批处理中的删除命令:del

    转载:https://blog.csdn.net/playboy1/article/details/6869358 删除一个或数个文件.DEL [/P] [/F] [/S] [/Q] [/A[[:]a ...

  4. SpringBoot logback 配置文件自定义属性

    添加自定义属性类 package com.cus.config; import ch.qos.logback.core.PropertyDefinerBase; import org.springfr ...

  5. ansible-playbook文件复用

    1. ansible-playbook文件复用  1.1) include 和 import区别  include(动态):在运行时导入 --list-tags,--list-tasks不会显示到输出 ...

  6. 多测师讲解selenium_iframe框定位_高级讲师肖sir

    iframe 框定位方法: 查看iframe框 京东点击登录定位元素 定位qq: qq登录定位的元素 查找iframe框 定位iframe框 from selenium import webdrive ...

  7. k8s集群添加新得node节点

    服务端操作: 方法一: 获取master的join token kubeadm token create --print-join-command 重新加入节点 kubeadm join 192.16 ...

  8. 扫描仪扫描文件处理-Photoshop批处理弹出色阶设置框解决

    为什么我录制动作明明设置的有色阶,最后批处理的时候仍然弹出了色阶设置框?   出现问题原因可能是你在录入设置色阶动作的时候,是彩色图片或者灰阶中的一种,而批处理的时候遇到了另外一种色彩模式.所以动作中 ...

  9. linux-查看内核

    [root@localhost vagrant]# uname -r 3.10.0-1127.19.1.el7.x86_64   [root@localhost vagrant]# cat /etc/ ...

  10. python 虚拟环境安装

    windows虚拟环境的搭建 安装 # 建议使用pip3安装到python3环境下 pip3 install virtualenv pip3 install virtualenvwrapper-win ...