题解 CF 1372 B
题目
题意
给出 \(n\),输出 \(a\) ,\(b\) (\(0 < a \leq b < n\)),使\(a+b=n\)且 \(\operatorname{lcm}(a,b)\) 最小。
思路
前言

如果你没有到现场,你永远也不会体验到cf 的 OI赛制有多强,评测队列曾超过15min,不得不让此次比赛unrated。

但是,我也不知道怎么B、C题提交把语言选成了:C11 ,然后在20分钟后完美地CE 了。
声明
lcm : 最小公倍数
minn : n 的最小质因数
mul : n 的最大 \(\neq n\) 的约数
分析
我们首先找出使 \(\operatorname{lcm}(a,b)\) 最小的 \(a\),\(b\)。
\(\because \operatorname{lcm}(a,b)=\frac{a\times b}{\gcd(a,b)}\) ,
\(\therefore\) 我们可以找到 \(n\) 最小的质因数 \(minn\) ,再找到 \(n\) 最大的约数(\(\neq n\))\(mul=\frac{n}{minn}\)。
当 \(n\) 为合数时,我们令答案为 \(mul\) , \((minn-1)\times mul\)。
当 \(n\) 为质数时,我们令答案为 \(1\) , \(n-1\)。
输出即可。
正确性
证1
证:当 \(n\) 为质数, \(k_1=1\) 时 ,\(\operatorname{lcm}(k_1,n-k_1)\) 最小
首先,设 \(k_1 > 0\),\(k_2=n-k_1\),且\(k_1<k_2\)。
\(\because\) \(n\) 为质数,\(\gcd(k_1,k_2) = 1\),
\(\therefore\) \(\operatorname{lcm}(k_1,k_2)=k_1\times (n-k_1)\)
当 \(k_1 = 1\) ,\(\operatorname{lcm}(k_1,k_2)=n-1\)
若 \(k_1 = 1 + h\)(\(1\leq h\leq \frac{n}{2}\)) ,则
\(\operatorname{lcm}(k_1,k_2)=(1+h)\times (n-1-h) = n - 1 +h \times (n-2-h) > n - 1\)
\(\therefore\) 当 \(n\) 为质数时,\(\operatorname{lcm}(1,n-1)\) 最小。
当然也可以表述为:当 \(n\) 为质数, \(a=1\) 时 ,\(a\times (n-a)\) 最小
类似地,我们也可证明: \(a=1\) 时 ,\(a\times (n-a)\) 最小
我们已经证明了情况2。
证2
证:当 \(n\) 为合数, \(k_1=mul\) 时,\(\operatorname{lcm}(k_1,n-k_1)\) 最小
首先,设 \(k_1 > 0\),\(k_2=n-k_1\),且\(k_1<k_2\) , \(q = \gcd(k_1,k_2) > 1\)。
令 \(n=g \times q\) , \(k_1=g_1 \times q\) ,\(k_2 = g_2\times q\) , \(g_1+g_2 =g\)
\(\operatorname{lcm}(k_1,n-k_2)=\frac{k_1 \times (n-k_1)}{q} = g_1\times q \times g_2\)
\(\therefore\) 当 \(g_1=1\) , \(g_1\times g_2\) 最小,
\(\therefore \operatorname{lcm}(k_1,n-k_2)=g_1\times q \times g_2 \geq (g-1)\times q =n - q\) (仅当 \(k_1 = q\) 等号成立)
我们再让 \(q\) 取最大为 \(mul\) 即可让\(\operatorname{lcm}(k_1,n-k_2)\) 最小 ,此时 \(k_1=mul\)
证明完毕(如有漏洞请轻喷)
算法
先用线性筛筛出1e5以内素数,方便找答案。
再一个个枚举素数,找到最小的质因子(如果有),判断情况(如果找不到 \(n\) 就肯定是素数),输出答案。
代码
/*
* Author :Werner_Yin
* Time: 2020-07-11 23:20:15
* I believe I can AC !
*/
#include <bits/stdc++.h>
#define lol long long
#define GDB(x) cout<<"DATA "<<#x<<" :"<<x<<endl;
#define mes(x) memset(x,0,sizeof(x))
using namespace std;
template <typename T>
void re(T &x){
#define ge getchar()
x = 0;int sgn = 1;char ch = ge;
for(;!isdigit(ch);ch = ge) if(ch == '-') sgn = -1;
for(;isdigit(ch);ch = ge) x = (x<<1)+(x<<3)+(ch^48);
x *= sgn;
}
template <typename T>
void write(T x){
if(x == 0) putchar(48);
else if(x < 0) putchar('-');
int k = 0,que[20];
while(x > 0){
que[++k]=x % 10;
x /= 10;
}
for(int i = k;i > 0;i--) putchar(que[i] + 48);
return;
}
const int MAXN = 1e5 + 10;
int PrimeNum = 0,Prime[MAXN];
bool IsNotPrime[MAXN];
void shai (){
for(int i = 2;i < MAXN;i++){
if(!IsNotPrime[i]){
Prime[PrimeNum++] = i;
}
for(int j = 0;j < PrimeNum && Prime[j] * i < MAXN;j++){
IsNotPrime[Prime[j] * i] = 1;
if(i % Prime[j])break;
}
}
}
int main (){
shai();
int T;
re(T);
while(T--){
int n;
re(n);
int minn = -1;
for(int i = 0;i < PrimeNum ;i++){
if(n % Prime[i] == 0){
minn = Prime[i];
break;
}
}
int mul = n / minn;
if(minn == -1||mul == 1) {write(1);write(n-1);}
else{write ( 1 * mul);write( (minn-1)*mul);}
putchar('\n');
}
return 0;
}
题解 CF 1372 B的更多相关文章
- 竞赛题解 - CF Round #524 Div.2
CF Round #524 Div.2 - 竞赛题解 不容易CF有一场下午的比赛,开心的和一个神犇一起报了名 被虐爆--前两题水过去,第三题卡了好久,第四题毫无头绪QwQ Codeforces 传送门 ...
- 题解——CF Manthan, Codefest 18 (rated, Div. 1 + Div. 2) T5(思维)
还是dfs? 好像自己写的有锅 过不去 看了题解修改了才过qwq #include <cstdio> #include <algorithm> #include <cst ...
- 竞赛题解 - [CF 1080D]Olya and magical square
Olya and magical square - 竞赛题解 借鉴了一下神犇tly的博客QwQ(还是打一下广告) 终于弄懂了 Codeforces 传送门 『题目』(直接上翻译了) 给一个边长为 \( ...
- [题解] [CF 1250J] The Parade
题面 题目大意: 给定一个 \(n\) , 所有军人的数量均在 \([1, n]\) 给定 \(a_i\) 代表高度为 \(i\) 的军人的个数 你要将这些军人分成 \(k\) 行, 满足下面两个条件 ...
- 题解——CF Manthan, Codefest 18 (rated, Div. 1 + Div. 2) T4(模拟)
随便模拟下就过了qwq 然后忘了特判WA了QwQ #include <cstdio> #include <algorithm> #include <cstring> ...
- 题解——CF Manthan, Codefest 18 (rated, Div. 1 + Div. 2) T3(贪心)
是一道水题 虽然看起来像是DP,但其实是贪心 扫一遍就A了 QwQ #include <cstdio> #include <algorithm> #include <cs ...
- 题解——CF Manthan, Codefest 18 (rated, Div. 1 + Div. 2) T2(模拟)
题目要求很简单,做法很粗暴 直接扫一遍即可 注意结果会爆int #include <cstdio> #include <algorithm> #include <cstr ...
- 题解——CF Manthan, Codefest 18 (rated, Div. 1 + Div. 2) T1(找规律)
就是找一下规律 但是奈何昨天晚上脑子抽 推错了一项QwQ 然后重新一想 A掉了QwQ #include <cstdio> #include <algorithm> #inclu ...
- 题解 CF 1372A
题目 传送门 题意 构造一个长度为n的数组,对于数组中的元素a,b,c,满足\(a+b\neq c\). 思路 直接让数组中的数全部变成1就可以了(其他数也行). 代码 /* * Author :We ...
随机推荐
- leetcode-cn 剑指offer
目录 面试题06 从尾到头打印链表 面试题07 重建二叉树 面试题09 用两个栈实现队列 面试题10- I 斐波那契数列 面试题11 旋转数组的最小数字 面试题12. 矩阵中的路径 面试题52. 两个 ...
- 解决:Invalid character found in the request target.The valid characters are defined in RFC 7230 and RF
背景 在将tomcat升级到7.0.81版后,发现系统的有些功能不能使用了,查询日志发现是有些地址直接被tomcat认为存在不合法字符,返回HTTP 400错误响应,错入信息如下: 原因分析 经了解, ...
- 【解读】Https协议
一.为什么需要https 1.HTTP是明文传输的,也就意味着,介于发送端.接收端中间的任意节点都可以知道你们传输的内容是什么.这些节点可能是路由器.代理等. 举个最常见的例子,用户登陆.用户输入账号 ...
- Css教程玉女心经版本
视频参见:php中文网css玉女心经视频教程 Css教程玉女心经版本 第1章 :css快速入门 1.1 什么是css 改变html框架的样式. 1.2 css的三种引入形式 第 ...
- Python 分布式缓存之Reids数据类型操作
目录 1.Redis API 2.String 操作 3.Hash 操作 4.List 操作 1.Redis API 1.操作模式 redis-py提供两个类Redis和StrictRedis用于实现 ...
- Day10-微信小程序实战-交友小程序-创建friendList字段实现好友关系(添加好友功能)--内附代码
回顾:之前我们进行了删除的功能,以及对message消息的增删,下面实现添加好友的功能 我们先在数据库中,在message这个字段的list里面,添加上测试号的id,就是模拟这个两个测试号要加我主号的 ...
- 入门大数据---Spark_Transformation和Action算子
一.Transformation spark 常用的 Transformation 算子如下表: Transformation 算子 Meaning(含义) map(func) 对原 RDD 中每个元 ...
- java后端无法接收到前端传递的json对象
java后端无法接收到前端传递的json对象 一·可能是因为未使用@RequestBody 在Controller层中,要么使用@RestController要么使用@Controller+@@Req ...
- Java设计模式十九——责任链模式
责任链模式 老李的苦恼 每个人在出生的时候,都早已在暗中被标好了三六九等. 老李是一名建筑工地的木匠,和大多数生活在社会最底层的农民工一样,一辈子老实本分,胆小怕事.在他们的心中,谁当老爷都没有区别, ...
- 洛谷P1220关路灯【区间dp】
题目描述 某一村庄在一条路线上安装了 \(n\) 盏路灯,每盏灯的功率有大有小(即同一段时间内消耗的电量有多有少).老张就住在这条路中间某一路灯旁,他有一项工作就是每天早上天亮时一盏一盏地关掉这些路灯 ...