CF1471-B. Strange List
CF1471-B. Strange List
题意:
给定一个由\(n\)个数字组成的数组以及一个\(x\)。现在从前往后遍历数组,若当前遍历的数字\(a[i]\)可以被\(x\)整除,那么就在数组的最后加上\(x\)个数字\(\frac {a[i]}x\);若当前遍历的数字不能被\(x\)整除,那么就停止遍历。
问题是当遍历完这个数组之后,数组中所有数字的总和\(\sum_{i=1}^na[i]\)等于多少。
思路:
本题一开始是想通过模拟整个过程来计算结果的,当时很不幸在测试test5
的时候MLE了,所以这题出题人本意肯定是让找出规律。
首先要想明白的明白的是,假设数字\(a[i]\)可以被\(x\)整除,那么整个数组所有数字的总和就会被加上\(\frac{a[i]}x * x\)也就是\(a[i]\)这么多;对于被加到数组后面的\(\frac{a[i]}x\),如果有一个\(\frac{a[i]}x\)可以被再次遍历到,那么其他所有的\(\frac{a[i]}x\)也都可以遍历到(原因很明显,他们是并排放进去的),若\(\frac{a[i]}x\)还可以被\(x\)整除,那么对于每个\(\frac{a[i]}x\)都会在数组最后加上\(x\)个\(\frac{\frac{a[i]}x}x\),那么一个\(x\)个\(\frac{a[i]}x\),所以数组所有数字总和一共加上了\(x*x*\frac{\frac{a[i]}x}x\)这么多,约分一下还是\(a[i]\)这么多。若继续下去会发现,每次都是加上了\(a[i]\)这么多。
现在假设这\(n\)个数字,每个数字能被\(x\)除的次数为\(b[i]\),那么在不考虑其他限制条件的情况下,每个数字能够对数组数字总和的额外贡献最多可以是\(a[i]*b[i]\)(根据上面的结论,一个数字被整除一次就可以多贡献\(a[i]\))。
但是实际上每个数字并不是都能贡献\(b[i]\)这么多次,原因在于:如果其中一个数字的\(b[i]\)太小了,比如特别极端的,\(b[i]=1\)的话,那么对于其他任何数字\(a[j]\)他们最多只能贡献两次,第一次是\(a[j]\)的时候,一次是\(\frac{a[j]}x\)的时候(这一次不一定能够遍历到,需要满足\(j<i\),这里的\(i\)是所有的最小的\(b[i]\)中最小的\(i\)),因为当数组遍历到\(\frac{a[i]}x\)的时候,这个数字不能再被\(x\)整除,数组的遍历就会结束,那么对于后面的数字虽然\(b[j]\)可能会很大,但是数组不能够遍历到那里了,也就不会再有贡献了。
所以要取得所有数字中\(b[i]\)的最小值,这里设最小值为\(b_{min}\),这里的\(min\)为出现最早的\(min\),即若\(b[i]\)的最小值为\(1\),有\(b[2]=1, b[3]=1\),那么就取\(min=2\),原因就是上面说到的,要求满足\(j<i\),\(i\)是所有的最小的\(b[i]\)中最小的\(i\)。
那么遍历完数组之后,整个数组数字之和\(Sum=\sum_{i=1}^{min-1}a[i]*(b[min]+1)+\sum_{i=min}^na[i]*b[min]+W\),其中\(W\)是在不遍历数组的时候,数组中所有数字的总和。
AC代码:
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
typedef long long ll;
const int INF = 0x3f3f3f3f;
const int Maxn = 100005;
ll a[Maxn];
int b[Maxn];
void solve() {
memset(b, 0, sizeof b);
int n, minn = INF;
ll x, ans = 0;
scanf("%d %lld", &n, &x);
for (int i = 0; i < n; i++) {
scanf("%lld", a + i);
ans += a[i];
ll t = a[i];
while (t % x == 0) {
b[i]++;
t /= x;
}
minn = std::min(minn, b[i]);
}
bool flag = true;
for (int i = 0; i < n; i++) {
if (b[i] == 0) {
break;
}
if (b[i] == minn) {
flag = false;
}
if (flag) {
ans += (minn + 1) * a[i];
} else {
ans += minn * a[i];
}
}
printf("%lld\n", ans);
}
int main() {
int T;
scanf("%d", &T);
while (T--) {
solve();
}
return 0;
}
CF1471-B. Strange List的更多相关文章
- timus 1175. Strange Sequence 解题报告
1.题目描述: 1175. Strange Sequence Time limit: 1.0 secondMemory limit: 2 MB You have been asked to disco ...
- CF719C. Efim and Strange Grade[DP]
C. Efim and Strange Grade time limit per test 1 second memory limit per test 256 megabytes input sta ...
- HDU 1548 A strange lift (最短路/Dijkstra)
题目链接: 传送门 A strange lift Time Limit: 1000MS Memory Limit: 32768 K Description There is a strange ...
- ACM : HDU 2899 Strange fuction 解题报告 -二分、三分
Strange fuction Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tot ...
- POJ 2891 Strange Way to Express Integers(拓展欧几里得)
Description Elina is reading a book written by Rujia Liu, which introduces a strange way to express ...
- A strange lift_BFS
Problem Description There is a strange lift.The lift can stop can at every floor as you want, and th ...
- HDU 1548 A strange lift (bfs / 最短路)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1548 A strange lift Time Limit: 2000/1000 MS (Java/Ot ...
- poj 2891 Strange Way to Express Integers (非互质的中国剩余定理)
Strange Way to Express Integers Time Limit: 1000MS Memory Limit: 131072K Total Submissions: 9472 ...
- A strange lift
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission( ...
- strange error encountered today in ROS
I reinstalled my ubuntu system and also ROS. I tested slam_karto package when some strange error cam ...
随机推荐
- 【Linux】ssh反映特别慢,但是网络没有问题的时怎么办
用crt连接服务器的时候,感觉很久才有反映,大约持续2秒以上,这种情况下,是解析的问题 这里有一个方法可以优化ssh cd /etc/ssh/ cp sshd_config sshd_config.b ...
- ctfhub技能树—文件上传—MIME绕过
什么是MIME MIME(Multipurpose Internet Mail Extensions)多用途互联网邮件扩展类型.是设定某种扩展名的文件用一种应用程序来打开的方式类型,当该扩展名文件被访 ...
- python中IF语句容易犯的错误CASE
python中没有switch case类似的语句,但是下面的IF语句却与之类似,却又不同: A = B = C = D = E = 1 if A == 1: B=2 elif B ==2: C= ...
- Spring Initializr中生成的mvnw是干吗的?
当我们使用Spring Initializr来创建Spring Boot工程的时候,有没有发现在工程根目录下有两个名为mvnw的文件: 从命名.图标.扩展名来猜测,这两个文件的作用应该是一样的,只是c ...
- linux搭建ARM可调式环境
0x00 前言 本文中所介绍的方法目前只测试了单个的demo,并没有拿大型的项目做测试,但是应该是大同小异.这里介绍两种方法,一种是有独立的ARM硬件,另一种是依靠qemu实现的模拟化,其实其本质都是 ...
- 基于源码分析Vue的nextTick
摘要:本文通过结合官方文档.源码和其他文章整理后,对Vue的nextTick做深入解析.理解本文最好有浏览器事件循环的基础,建议先阅读上文<事件循环Event loop到底是什么>. 一. ...
- babel : 无法加载文件 C:\Users\win\AppData\Roaming\npm\babel.ps1,因为在此系统上禁止运行脚本。有关详细信息,请参阅 https:/ go.micros
babel报错:babel : 无法加载文件 C:\Users\win\AppData\Roaming\npm\babel.ps1,因为在此系统上禁止运行脚本.有关详细信息,请参阅 https:/ g ...
- HA工作机制及namenode向QJM写数据流程
HA工作机制 (配置HA高可用传送门:https://www.cnblogs.com/zhqin/p/11904317.html) HA:高可用(7*24小时不中断服务) 主要的HA是针对集群的mas ...
- Springboot中mybatis控制台打印sql语句
Springboot中mybatis控制台打印sql语句 https://www.jianshu.com/p/3cfe5f6e9174 https://www.jianshu.com/go-wild? ...
- mysql中int型的数字怎么转换成字符串
字段:number 是integer类型 在表test中 select cast(number as char) as number from test; 或者convert()方法.因为转换 ...