Codeforces H. Maximal GCD(贪心)
题目描述:
1 second
256 megabytes
standard input
standard output
You are given positive integer number n. You should create such strictly increasing sequence of k positive numbers a1, a2, ..., ak, that their sum is equal to n and greatest common divisor is maximal.
Greatest common divisor of sequence is maximum of such numbers that every element of sequence is divisible by them.
If there is no possible sequence then output -1.
The first line consists of two numbers n and k (1 ≤ n, k ≤ 1010).
If the answer exists then output k numbers — resulting sequence. Otherwise output -1. If there are multiple answers, print any of them.
6 3
1 2 3
8 2
2 6
5 3
-1
思路:
这个题是要给一个数n,一个数k,看能不能凑出一组含k个元素的严格递增数列,这组数的和为n,还要让这组数的最大公约数最大。
刚开始,a1+a2+...+ak=n>=a1+(a1+1)+(a1+2)+...+(ak+k-1),解得1<=a1<=(n-k*(k-1)/2)/k,既然要求公约数最大,把a的所有因数找出来,从大往小一个个试,
比如,找到一个f是a1的因数,既然要f为这组数的gcd,那f一定也是n的因数,检查一下,不是就跳过,是就n/f,变成找一个严格递增数列和为n/f,就不用考虑公因数了。
刚开始把过多的注意力放到了a1上,就把所有a1可能值一个个遍历,分别找因数,分别检查,结果是错的,而且程序逻辑及其混乱+复杂,还有好多要特判的地方(疯了我已经快)因为每一个a1都有因数1,最后对于较大的a1来说(从大往小检查)总会到1就停止,以为算出了最终结果。
所以后来把所有a的所有因数放到一个set里,也方便找最大值,从大往小遍历所有因数。就好了。。。吗?
结果超时。
仔细想想,怎么办。既然最后都是a1的因数f如果满足题目条件,那么它也是n的因数,那就把n的因数找出来就好了啊。
(٩(๑>◡<๑)۶),注意的是在枚举n的因数是不要忘了f要满足a1的上下界的限制,满足的才加到set中去。
但是但是,还要注意,一开始判断可不可能构造出这么一个数列,a1+a2+...+ak=n>=ka1+k*(k-1)/2>=k+k*(k-1)/2,以为完了?nonono,要注意题目数据范围,如果来个4*10^9这种,long long也存不下啊,那咋办,用double来存k吧...
|
Type |
Size |
数值范围 |
|
无值型void |
0 byte |
无值域 |
|
布尔型bool |
1 byte |
true false |
|
有符号短整型short [int] /signed short [int] |
2 byte |
-32768~32767 |
|
无符号短整型unsigned short [int] |
2 byte |
0~65535 |
|
有符号整型int /signed [int] |
4 byte |
-2147483648~2147483647 |
|
无符号整型unsigned [int] |
4 byte |
0~4294967295 |
|
有符号长整型long [int]/signed long [int] |
4 byte |
-2147483648~2147483647 |
|
无符号长整型unsigned long [int] |
4 byte |
0~4294967295 |
|
long long |
8 byte |
0~18446744073709552000 |
|
有符号字符型char/signed char |
1 byte |
-128~127 |
|
无符号字符型unsigned char |
1 byte |
0~255 |
|
宽字符型wchar_t (unsigned short.) |
2 byte |
0~65535 |
|
单精度浮点型float |
4 byte |
-3.4E-38~3.4E+38 |
|
双精度浮点型double |
8 byte |
1.7E-308~1.7E+308 |
|
long double |
8 byte |
(上表来源见下面博客)
知识点:贪心,数论(一点点)
代码:
#include <iostream>
#include <cmath>
#include <vector>
#include <set>
#include <algorithm>
using namespace std;
long long n;
double k;
set<long long> fac;
vector<long long> num;
int main()
{
cin >> n >> k;
if(k+k*(k-)/<=n)
{
long long uper1 = (n-k*(k-)/)/k;
long long lower1 = ;
//cout << uper1 << " " << lower1 << endl;
long long qz = ;
/*for(long long a = uper1; a>=lower1; a--)
{
for(long long i = 1; i<sqrt(a)+1; i++)
{
if(a%i==0)
{
fac.insert(i);
fac.insert(a/i);
}
}
}*/
for(long long i = ;i<sqrt(n)+;i++)
{
if(n%i==)
{
if(i<=uper1)
{
fac.insert(i);
}
if(n/i<=uper1)
{
fac.insert(n/i);
}
}
}
/*cout << "fac " << endl;
for(auto ite = fac.rbegin();ite!=fac.rend();ite++)
{
cout << *ite << " ";
}
cout << endl;*/
for(auto ite = fac.rbegin(); ite!=fac.rend(); ite++)
{
//cout << "ite " << *ite << endl;
int flag = ;
num.clear();
long long sum = n/(*ite)-;
int shu = ;
num.push_back(shu);
if(sum)
{
shu++;
while(shu<=sum&&num.size()<k-)
{
num.push_back(shu);
sum -= shu;
shu++; }
if(shu<=sum)
{
qz = *ite;
//cout << "qz " << qz << endl;
num.push_back(sum);
break;
}
}
else
{
qz = *ite;
break;
}
}
for(int i = ;i<num.size();i++)
{
cout << qz*num[i] << " ";
}
cout << endl;
}
else
{
cout << - << endl;
}
return ;
}
参考资料:
年少轻狂12138,C++基本数据类型大小及表示范围,https://blog.csdn.net/weixin_40709898/article/details/79368310(间接引用,因为上面的博客也是转载但找不到原博客)
Codeforces H. Maximal GCD(贪心)的更多相关文章
- CodeForce-803C Maximal GCD(贪心数学)
Maximal GCD CodeForces - 803C 现在给定一个正整数 n.你需要找到 k 个严格递增的正整数 a1, a2, ..., ak,满足他们的和等于 n 并且他们的最大公因数尽量大 ...
- codeforces 803C Maximal GCD(GCD数学)
Maximal GCD 题目链接:http://codeforces.com/contest/803/problem/C 题目大意: 给你n,k(1<=n,k<=1e10). 要你输出k个 ...
- Codeforces 803C. Maximal GCD 二分
C. Maximal GCD time limit per test: 1 second memory limit per test: 256 megabytes input: standard in ...
- 【数学】codeforces C. Maximal GCD
http://codeforces.com/contest/803/problem/C [题意] 给定两个数n,k(1 ≤ n, k ≤ 10^10) 要你输出k个数,满足以下条件: ①这k个数之和等 ...
- CodeForces - 803C Maximal GCD 【构造】
You are given positive integer number n. You should create such strictly increasing sequence of k po ...
- Codeforces 803C. Maximal GCD
题目链接:http://codeforces.com/contest/803/problem/C 中了若干trick之后才过... k个数的严格递增序列最小权值和就是${n*(n+1)/2}$,枚举这 ...
- Maximal GCD CodeForces - 803C (数论+思维优化)
C. Maximal GCD time limit per test 1 second memory limit per test 256 megabytes input standard input ...
- AC日记——Maximal GCD codeforces 803c
803C - Maximal GCD 思路: 最大的公约数是n的因数: 然后看范围k<=10^10; 单是答案都会超时: 但是,仔细读题会发现,n必须不小于k*(k+1)/2: 所以,当k不小于 ...
- Educational Codeforces Round 20 C. Maximal GCD
C. Maximal GCD time limit per test 1 second memory limit per test 256 megabytes input standard input ...
随机推荐
- byte类型的取值为什么是-128~127
参考:https://blog.csdn.net/qq_22771739/article/details/84496115 https://blog.csdn.net/boatalways/artic ...
- 安装 gearman
准备:php 对应gearman插件包 https://pecl.php.net/package/gearman 1. 先安装依赖库 [root@VM_27_0_centos /]# yum inst ...
- php利用crontab执行 5分钟发邮件给用户 (包含每分钟发一次)
php利用crontab执行 5分钟发邮件给用户 一开始设想用shell_exec执行sh 运行 crontab但发现并不可取 因为没办法传变量 (因为要传963529987@qq.com)所以决定采 ...
- 在ensp上利用单臂路由实验VLAN间路由
我们为什么要设置单臂路由? 因为我们要解决不同vlan,不同网络的PC机间的通信问题~ 那它为啥叫单臂路由嘞? 单臂路由的原理时通过一台路由器,使vlan间互通数据通过路由器进行三层转发,如果在路由器 ...
- Java 8 集合之流式(Streams)操作, Streams API 详解
因为当时公司的业务需要对集合进行各种各样的业务逻辑操作,为了提高性能,就用到了这个东西,因为以往我们以前用集合都是需要去遍历(串行),所以效率和性能都不是特别的好,而Streams就可以使用并行的方式 ...
- LeetCode 704. 二分查找(Binary Search)
704. 二分查找 704. Binary Search 题目描述 给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target,写一个函数搜索 nums 中的 target,如果 ...
- linux根据进程名终止进程
2017年09月25日 19:44:32 aladdin_sun 阅读数 5235 linux根据进程名终止进程 实验环境 操作系统:CentOS Linux release 7.3.1611 ( ...
- 删除List集合中的元素你碰到过这样的陷阱吗?
删除List的三种方式: (1) 普通遍历 : @Test public void testList(){ ArrayList<String> list = new ArrayList&l ...
- STL源码剖析——序列式容器#2 List
list就是链表的实现,链表是什么,我就不再解释了.list的好处就是每次插入或删除一个元素,都是常数的时空复杂度.但遍历或访问就需要O(n)的时间. List本身其实不难理解,难点在于某些功能函数的 ...
- python3与Excel的完美结合
https://segmentfault.com/a/1190000016256490 Excel 是 Windows 环境下流行的.强大的电子表格应用.openpyxl 模块让 Python 程序能 ...