CF402D 【Upgrading Array】
题目链接:
题目分析:
首先考虑一下怎么求每个数的分数。把每个数分解到最后会发现它的坏质因子对它分数的贡献是\(-1\),好质因子对它分数的贡献是\(1\),那么最后的分数就是好质因数-坏质因数
然后想一想怎么操作。我们的最优答案是把所有能除掉的负数分数的\(gcd\)全部除掉,一个很显然的贪心是从后往前操作,因为前面操作了之后后面的\(gcd\)就恒为\(1\),操作不下去了
另一个\(point\)是操作是显然正确的,因为后面的操作会除掉前面操作原本的\(gcd\)的一部分,而剩下的一部分应该被除掉的会在之后的贪心中被除去
举个例子
假设区间\([1, 5]\)需要被除掉的\(gcd\)是\(12\),区间\([1, 9]\)需要被除掉的\(gcd\)是\(4\),那么在\(9\)号位上除去\(4\)后再在\(5\)号位上除去\(3\)即可
处理一下前缀\(gcd\),从后向前贪心,并记录当前已经除去了多少,每次进行操作之前要先除去这个量。(另:素数只需筛到\(sqrt(1e9)\)即可,后面的可以暴力判断),对于每一位,质因数分解一下当前位置上的前缀\(gcd\)并计算它的分数,如果\(<0\)就除掉它
用\(bitset\)记录坏质数
代码:
#include<bits/stdc++.h>
#define N (100000 + 5)
using namespace std;
int n, m, prime[N], tot, ans, g[N];
bool vis[N];
bitset <1000000005> S;inline int read() {
int cnt = 0, f = 1; char c = getchar();
while (!isdigit(c)) {if (c == '-') f = -f; c = getchar();}
while (isdigit(c)) {cnt = (cnt << 3) + (cnt << 1) + (c ^ 48); c = getchar();}
return cnt * f;
}
int a[N], b[N];
int gcd(int a, int b) {return b ? gcd(b, a % b) : a;}
void init() {
for (register int i = 2; i <= N - 5; ++i) {
if (!vis[i]) vis[i] = 1, prime[++tot] = i;
for (register int j = 1; j <= tot && prime[j] * i <= N - 5; ++j) {
vis[i * prime[j]] = 1;
if (i % prime[j] == 0) break;
}
}
}
int divide(int x) {
int ans = 0;
for (register int i = 1; i <= tot && prime[i] * prime[i] <= x; ++i) {
while (x % prime[i] == 0) ans += S[prime[i]] ? -1 : 1, x /= prime[i];
}
if (x > 1) ans += S[x] ? -1 : 1;
return ans;
}
int main() {
n = read(), m = read();
for (register int i = 1; i <= n; ++i) a[i] = read();
for (register int i = 1; i <= m; ++i) S[read()] = 1;
init();
for (register int i = 1; i <= n; ++i) ans += divide(a[i]);
for (register int i = 1; i <= n; ++i) g[i] = gcd(g[i - 1], a[i]);
int div = 1;
for (register int i = n; i >= 1; --i) {
g[i] /= div;
int x = divide(g[i]);
if (x < 0) ans += i * (-x), div *= g[i];
}
printf("%d\n", ans);
return 0;
}
CF402D 【Upgrading Array】的更多相关文章
- 【system.array】使用说明
对象:system.array 说明:提供一系列针对数组类型的操作 目录: 方法 返回 说明 system.array.join( array, separator ) [String] 将数组转换 ...
- 【费用流】【Next Array】费用流模板(spfa版)
#include<cstdio> #include<algorithm> #include<cstring> #include<queue> using ...
- 【网络流】【Dinic】【Next Array】Dinic模板
注意:有时加边不一定要加反向弧. Next Array版. #include<cstdio> #include<cstring> #include<algorithm&g ...
- 【wx:for】小程序列表渲染的使用说明
wx:for 控制属性绑定一个数组,即可使用数组中各项的数据重复渲染该组件. 默认数组的当前项的下标变量名默认为 index,数组当前项的变量名默认为 item,即: {{index}} . {{it ...
- noip模拟【array】
array by ysy [题目描述] 给定一个长度为n的数列,每次你可以进行以下操作之一: (1)将一个数+a: (2)将一个数-a: (3)将一个数+b: (4)将一个数-b: 你需要将所有数全部 ...
- 【js实例】Array类型的9个数组方法,Date类型的41个日期方法,Function类型
前文提要:[js实例]js中的5种基本数据类型和9种操作符 Array类型的9个数组方法 Array中有9个数组方法: 1.检测数组 2.转换方法 3.栈方法 4.队列方法 5.冲排序方法6.操作方法 ...
- 【Python】【内置函数】【bytes&bytearray&str&array】
[bytes] 英文文档: class bytes([source[, encoding[, errors]]]) Return a new “bytes” object, which is an i ...
- 【刷题】Search in a Big Sorted Array
原题戳我. 题目 Description Given a big sorted array with positive integers sorted by ascending order. The ...
- PHP:微信小程序调用【统一下单】【微信支付】【支付回调】API;XML转Array,Array转XML方法(通用)
1.微信公众号.微信小程序开发过程中,第三方服务器与微信服务器数据交互,需要进行数据转换,必须用到这两个函数: 分别是xml_to_array.array_to_xml ; /** * 输出xml字符 ...
随机推荐
- Spring Boot 文件下载
1. 文件下载类 import javax.servlet.http.HttpServletResponse; import java.io.*; public class DownloadUtil ...
- (二十三)Http请求的处理过程
- Docker学习のDocker初识
一.Docker是什么 Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从Apache2.0协议开源. Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然 ...
- spring MVC 转发与重定向(传参)
return "forward:index.jsp"; //转发 return "forward:user.do?method=reg5"; //转发 ret ...
- arm-linux-strip 的使用
3.2.1 1. 移除所有的符号信息 [arm@localhost gcc]#cp hello hello1 [arm@localhost gcc]#armlinuxstrip strip ...
- expect离线安装
expect5.45.4.tar.gz和tcl8.4.11-src.tar.gz压缩包请前往以下链接下载: https://download.csdn.net/download/gangzi221/1 ...
- 各种版本mysql驱动包下载地址
http://central.maven.org/maven2/mysql/mysql-connector-java/
- gradle配置全局仓库
1.在系统环境变量中配置: GRADLE_USER_HOME=D:\gradleRepository 2.在配置的路径中,增加文件init.gradle allprojects{ repositori ...
- Mysql优化系列之索引性能
实际上,前面的数据类型和表结构设计优化不能算优化,只能算规范,也就是说在设计表的时候,应该且必须做到这些 索引是sql优化的核心部分,在<高性能Mysql>中单独抽出一章讲,也印证了其重要 ...
- Kindle电子书制作
text.html: <!DOCTYPE html> <html lang="en"> <head> <meta http-equiv=& ...