BZOJ 4454: C Language Practice
4454: C Language Practice
Time Limit: 20 Sec Memory Limit: 24 MB
Submit: 501 Solved: 112
[Submit][Status][Discuss]
Description

Input
Output
Sample Input
3 2
5 9 6
3 4
2 2
8 9
0 6
1 1
9
6
Sample Output
22
3
HINT
注意:此题只有一个数据点。
Source
$O(N)-O(1)$的gcd黑科技
#include <cstdio> inline char Char(void)
{
static const int siz = ; static char buf[siz];
static char *hd = buf + siz;
static char *tl = buf + siz; if (hd == tl)
fread(hd = buf, , siz, stdin); return *hd++;
} inline int Int(void)
{
int ret = , neg = , c = Char(); for (; c < ; c = Char())
if (c == '-')neg ^= true; for (; c > ; c = Char())
ret = ret * + c - ''; return neg ? -ret : ret;
} int g[][]; int fac[][]; int pre[], pri[], tot; inline int gcd(int a, int b)
{
if (a <= && b <= )
return g[a][b]; int ret = ; for (int i = ; i < ; ++i)
if (fac[a][i] != )
{
int t = fac[a][i]; if (pre[t])
{
int d = g[t][b % t];
ret *= d, b /= d;
}
else if (b % t == )
ret *= t, b /= t;
} return ret;
} signed main(void)
{
for (int i = ; i <= ; ++i)
for (int j = ; j <= ; ++j)
if (i == || j == )
g[i][j] = i + j;
else if (g[j][i % j])
g[i][j] = g[j][i % j];
else if (g[i % j][j])
g[i][j] = g[i % j][j];
else if (g[i][j % i])
g[i][j] = g[i][j % i];
else if (g[j % i][i])
g[i][j] = g[j % i][i]; fac[][] = fac[][] = fac[][] = ; for (int i = ; i <= ; ++i)
{
if (!pre[i])pri[++tot] = i,
fac[i][] = fac[i][] = , fac[i][] = i; for (int j = ; j <= tot && pri[j] * i <= ; ++j)
{
int num = pri[j] * i, p = pri[j]; pre[num] = p;
fac[num][] = fac[i][];
fac[num][] = fac[i][];
fac[num][] = fac[i][]; if (fac[num][] * p <= )
fac[num][] *= p;
else if (fac[num][] * p <= )
fac[num][] *= p;
else
fac[num][] *= p;
}
} for (int cas = Int(); cas--; )
{
static int n, m, a[], b[]; n = Int();
m = Int(); for (int i = ; i < n; ++i)
a[i] = Int(); for (int i = ; i < m; ++i)
b[i] = Int(); unsigned ans = ; for (int i = ; i < n; ++i)
for (int j = ; j < m; ++j)
ans += gcd(a[i], b[j]) ^ i ^ j; printf("%u\n", ans);
}
}
@Author: YouSiki
BZOJ 4454: C Language Practice的更多相关文章
- BZOJ4454: C Language Practice
Description Input 第一行输入一个正整数T(T<=85),表示测试数据的组数. 每组数据第一行包含两个正整数n,m(1<=n,m<=2000),表示序列的长度. 第二 ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- 英语口语考试资料Language learning
"Learning a language is easy. Even a child can do it!" Most adults who are learning a seco ...
- 100 天从 Python 新手到大师
Python应用领域和就业形势分析 简单的说,Python是一个“优雅”.“明确”.“简单”的编程语言. 学习曲线低,非专业人士也能上手 开源系统,拥有强大的生态圈 解释型语言,完美的平台可移植性 支 ...
- Python - 100天从新手到大师
简单的说,Python是一个“优雅”.“明确”.“简单”的编程语言. 学习曲线低,非专业人士也能上手 开源系统,拥有强大的生态圈 解释型语言,完美的平台可移植性 支持面向对象和函数式编程 能够通过调用 ...
- 国内某Python大神自创完整版,系统性学习Python
很多小伙伴纠结于这个一百天的时间,我觉得完全没有必要,也违背了我最初放这个大纲上来的初衷,我是觉得这个学习大纲还不错,自学按照这个来也能相对系统的学习知识,而不是零散细碎的知识最后无法整合,每个人的基 ...
- 课程五(Sequence Models),第二 周(Natural Language Processing & Word Embeddings) —— 0.Practice questions:Natural Language Processing & Word Embeddings
[解释] The dimension of word vectors is usually smaller than the size of the vocabulary. Most common s ...
- 【BZOJ】【3053】The Closest M Points
KD-Tree 题目大意:K维空间内,与给定点欧几里得距离最近的 m 个点. KD树啊……还能怎样啊……然而扩展到k维其实并没多么复杂?除了我已经脑补不出建树过程……不过代码好像变化不大>_&g ...
- BZOJ 4576: [Usaco2016 Open]262144
Description 一个序列,每次可以将两个相同的数合成一个数,价值+1,求最后最大价值 \(n \leqslant 262144\) Sol DP. 这道题是 BZOJ 4580: [Usaco ...
随机推荐
- linux centos7 nginx 安装部署和配置
1/什么是NginxNginx("enginex")是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP代理服务器,在高连接并发的情况下Nginx是Apac ...
- Linux系统中时间区域和API
1.问题 在开发云平台程序的时候,经常会碰到时间区域转换的问题.比如,任何网络存储的文档的metadata都自己记录了编辑时间.但是,云平台记录时需要把这个时间转成标准时间,便于管理.但是用户使用的时 ...
- mysql innodb 从 ibd 文件恢复表数据
最近内部的 mysql 数据库发生了一件奇怪的事,其中有一个表 users625 突然出现问题, 所有对它的操作都报错误 数据表不存在. mysql> select count(*) from ...
- 6.capacity scheduler
1.先决条件 要使用yarn的capcitiy调度器,必须开启yarn的ACLs,否则队列ACLs设置不生效 开启yarn ACLs: # hadoop: core-site.xml hadoop ...
- scrum立会报告+燃尽图(第二周第二次)
此作业要求参考: https://edu.cnblogs.com/campus/nenu/2018fall/homework/2247 一.小组介绍 组名:杨老师粉丝群 组长:乔静玉 组员:吴奕瑶.公 ...
- Notes of Daily Scrum Meeting(11.15)
Notes of Daily Scrum Meeting(11.15) 今天周六我们的主要工作是把这周落下的一些工作补回来,这是写程序的最后阶段,准备进入测试阶段了,所以之前的工作 要补齐,今天大家的 ...
- C#获取周一、周日的日期 函数类
#region 得到一周的周一和周日的日期 /// <summary> /// 计算本周的周一日期 /// </summary> ...
- 关于JoptionPane提示框
import java.util.*; import javax.swing.JOptionPane; import javax.swing.UIManager; public class Main ...
- vmware_vcenter_api
VMware Vcenter_API 介绍 本文主要通过调用Vcenter_API,获取其中的数据中心,集群,主机,网络,存储,虚拟机信息. 开发语言 python 使用官方sdk pyvmomi 文 ...
- Alpha版本冲刺(二)
目录 组员情况 组员1(组长):胡绪佩 组员2:胡青元 组员3:庄卉 组员4:家灿 组员5:凯琳 组员6:丹丹 组员7:家伟 组员8:政演 组员9:黄鸿杰 组员10:刘一好 组员11:何宇恒 展示组内 ...