【Codeforces Round #432 (Div. 1) B】Arpa and a list of numbers
【链接】h在这里写链接
【题意】
【题解】
sum[R-1]-sum[R-x/y-1];
【错的次数】
【反思】
【代码】
/*
所有数字都等于1
①把n-1个数字删掉,剩下一个数字,再递增1? (n-1)*x + y = n*x + y - x
②或者,把n个数字都加上1,花费为n*y
n*x + y - x > n*y
n*x - n*y > x - y;
n*(x-y) > (x-y)
如果x > y
选第二种
如果x < y
选第一种
但是,也可以其中一些数字加上1,剩下的全删掉.
一个数字加上1之后,就不用删掉了.
所以,哪一个花费比较低,就优先操作那一个就好.
那最后如果全是选删掉怎么办?
那就只能留一个选增加了。
枚举最后的gcd为i.
然后如果一个数字比它小的话,就看一下加的费用和删的费用,哪一个比较大。
选那个费用比较小的。
然后选取费用差值最小的那个,以防全都被删掉了。
O(N^2)的复杂度了
比i小的数字,肯定是要删掉的->不一定,可以加到gcd.
但加到一定程度,就一定要删掉的。
因为删掉的花费不变,但是你一直增加,花费是会变多的。
但是也不一定能被i整除,整体的gcd就是i啊
give up. */ #include <bits/stdc++.h>
using namespace std; const int N = 2e6; int n;
long long num[N+10], sum[N+10],x,y,ans = -1; void inandpre() {
cin >> n >> x >> y;
for (int i = 1; i <= n; i++) {
int t;
cin >> t;
num[t]++, sum[t] += t;
} for (int i = 1; i <= N; i++)
sum[i] += sum[i - 1],num[i]+=num[i-1];
} const int M = 1e6;
bool iszs[M + 10];
vector <int> zsb;
void getzhishu() {
memset(iszs, true,sizeof iszs);
for (int i = 2; i <= M; i++){
if (iszs[i]) zsb.push_back(i);
int len = zsb.size();
for (int j = 0; j <= len - 1; j++) {
int t = zsb[j];
if (i*t > M) break;
iszs[i*t] = false;
if (i%t == 0) break;
}
}
} void meiju() {
for (int ii = 0; ii <= (int) zsb.size()-1; ii++) {
long long rest = 0;
int i = zsb[ii];
for (int j = i; j <= N; j += i) {
long long temp = x / y;
long long ju = j - temp,l = j-i+1,r = j;
ju = max(ju, l);
rest += x*(num[ju-1] - num[l - 1]);//删掉
rest += y*((num[r - 1] - num[ju - 1])*r - (sum[r-1]-sum[ju-1]));//加上
}
if (ans == -1)
ans = rest;
else
ans = min(ans, rest);
}
} void out() {
cout << ans << endl;
} int main() {
//freopen("F:\\rush.txt", "r", stdin);
ios::sync_with_stdio(0);
inandpre();
getzhishu();
meiju();
out();
return 0;
}
【Codeforces Round #432 (Div. 1) B】Arpa and a list of numbers的更多相关文章
- 【Codeforces Round #432 (Div. 2) A】 Arpa and a research in Mexican wave
[链接]h在这里写链接 [题意] 在这里写题意 [题解] t<=k,输出t t>=n,输出k-t+n 其他情况都是k [错的次数] 0 [反思] 在这了写反思 [代码] /* */ #in ...
- 【Codeforces Round #432 (Div. 2) B】Arpa and an exam about geometry
[链接]h在这里写链接 [题意] 给你3个点A,B,C 问你能不能将纸绕着坐标轴上的一点旋转.使得A与B重合,B与C重合 [题解] 这3个点必须共圆. 则A,B,C不能为一条直线.否则无解. 共圆之后 ...
- 【Codeforces Round #432 (Div. 1) A】 Five Dimensional Points
[链接]点击打开链接 [题意] 给你n个5维的点. 然后让你以其中的某一个点作为起点a. 另选两个点b,c. 组成向量a->b,a->c 如果所有的a->b和a->c的夹角都是 ...
- 【Codeforces Round #420 (Div. 2) C】Okabe and Boxes
[题目链接]:http://codeforces.com/contest/821/problem/C [题意] 给你2*n个操作; 包括把1..n中的某一个数压入栈顶,以及把栈顶元素弹出; 保证压入和 ...
- 【Codeforces Round #420 (Div. 2) B】Okabe and Banana Trees
[题目链接]:http://codeforces.com/contest/821/problem/B [题意] 当(x,y)这个坐标中,x和y都为整数的时候; 这个坐标上会有x+y根香蕉; 然后给你一 ...
- 【Codeforces Round #420 (Div. 2) A】Okabe and Future Gadget Laboratory
[题目链接]:http://codeforces.com/contest/821/problem/A [题意] 给你一个n*n的数组; 然后问你,是不是每个位置(x,y); 都能找到一个同一行的元素q ...
- 【Codeforces Round #423 (Div. 2) C】String Reconstruction
[Link]:http://codeforces.com/contest/828/problem/C [Description] 让你猜一个字符串原来是什么; 你知道这个字符串的n个子串; 且知道第i ...
- 【Codeforces Round #423 (Div. 2) B】Black Square
[Link]:http://codeforces.com/contest/828/problem/B [Description] 给你一个n*m的格子; 里面包含B和W两种颜色的格子; 让你在这个格子 ...
- 【Codeforces Round #423 (Div. 2) A】Restaurant Tables
[Link]:http://codeforces.com/contest/828/problem/A [Description] 有n个组按照时间顺序来餐馆; 每个组由一个人或两个人组成; 每当有一个 ...
随机推荐
- [Python] Reuse Code in Multiple Projects with Python Modules
A module is a function extracted to a file. This allows you to import the function and use it in any ...
- JSON初入门
JSON:Javascript Object Notation 轻量级的数据交换格式 语法规则:(JSON语法是js对象表示语法的子集) 1.数据在名称/值对中 2.数据由逗号分隔 3.花括号{}保存 ...
- Java的线程机制
一.Java中实现多线程的两种方式1) 继承Thread类 Thread类包括了包括和创建线程所需的一切东西. Thread 最重要的方法是 run().编写线程程序时须要覆盖 run() 方法,ru ...
- Cocos2d-x学习笔记(20)(TestCpp源代码分析-4)
本章主要介绍testResource.h与tests.h,当中tests.h主要是存放全部用到的头文件.与菜单相相应的宏定义以及菜单数组,testResource.h主要用是资源文件定义. //tes ...
- 懒加载js实现和优化
1.懒加载的作用和原理 在我们展示多图片的场景下,类似淘宝或者百度图片,由于图片的数目过多,全部从服务器请求会给用户糟糕的用户体验,为了提升用户体验,我们这里使用懒加载,随着下拉逐步加载. 每个图片的 ...
- 小程序block总结
小程序block总结 1.block并不是一个组件,它仅仅是一个包装元素,不会在页面中做任何渲染,只接受控制属性. 2.因为 wx:if 是一个控制属性,需要将它添加到一个标签上.如果要一次性判断多个 ...
- vue中computed与watch的异同
一.computed 和 watch 都可以观察页面的数据变化.当处理页面的数据变化时,我们有时候很容易滥用watch. 而通常更好的办法是使用computed属性,而不是命令是的watch回调. ...
- 用内置的库turtle来画一朵花,python3
题目:用内置的库turtle来画一朵花 看了群主最后成像的图片,应该是循环了36次画方框,每次有10度的偏移. 当然不能提前看答案,自己试着写代码. 之前有用过海龟画图来画过五角星.奥运五环.围棋盘等 ...
- Mysql学习总结(17)——MySQL数据库表设计优化
1.选择优化的数据类型 MySQL支持很多种不同的数据类型,并且选择正确的数据类型对于获得高性能至关重要.不管选择何种类型,下面的简单原则都会有助于做出更好的选择: (1).更小通常更好 一般来说,要 ...
- *android抓包工具——fiddler抓包分析api接口
本文地址:http://blog.csdn.net/u011733020 首先,写这个仅仅是为了学习.不是要做什么违法的事情,假设有问题,有关部门 请联系我,立刻删除. 不要查我水表. 正题:这里介绍 ...