2017 CCPC 湘潭邀请赛
都tm快一年了我还没补这套题……再不补怕是要留给退役后乐
Problem A
把$n * (n + 1)$的矩阵补成$(n + 1) * (n + 1)$的,然后高斯消元。
Problem B
一看题解:费用流,于是这个题直接交给队友。
Problem C
又是高斯消元……
Problem D
直接输出即可。
#include <bits/stdc++.h> using namespace std; #define rep(i, a, b) for (int i(a); i <= (b); ++i)
#define dec(i, a, b) for (int i(a); i >= (b); --i) const int N = 1e2 + 10; int c[N][N], f[N][N];
int n, m, a, b; int main(){ while (~scanf("%d%d%d%d", &n, &m, &a, &b)){
rep(i, 1, n){
rep(j, 1, m) scanf("%1d", c[i] + j);
} rep(i, 1, n * a){
rep(j, 1, m * b){
int x = (i - 1) / a + 1;
int y = (j - 1) / b + 1;
printf("%d", c[x][y]);
}
putchar(10);
}
} return 0;
}
Problem E
占坑。
Problem F
首先可以肯定的是 $f_{0} + f_{1} + f_{2} + f_{3} = m^{3}$
那么计算出其中的$3$个就可以得到剩余的$1$个。
显然$f_{0}$和$f_{3}$是比较好求的。
所以$f_{1}$和$f_{2}$求出一个,问题就解决了。
大概是……$f_{2}$比较好求?
求$f_{3}$的时候记录一下有哪些三元组是符合这个条件的。
首先枚举两个数,把他们放在$(1, 2)$,$(1, 3)$,$(2, 3)$的位置,然后枚举剩下那个数可以是什么。
首先在$a[]$中没有出现的并且在$[1, m]$中的数肯定可以放,这个直接单独计算。
枚举在$a[]$中出现过的数,得到一个新的三元组,根据题意这个三元组要么计入$f_{2}$要么计入$f_{3}$。
那么看一下是否计入了$f_{3}$,如果不在就计入$f_{2}$
坑点:可能出现$a_{i} > m$的情况。
#include <bits/stdc++.h> using namespace std; #define rep(i, a, b) for (int i(a); i <= (b); ++i)
#define dec(i, a, b) for (int i(a); i >= (b); --i) typedef long long LL; const int N = 2e2 + 10;
const int M = 1e7 + 10; LL f0, f1, f2, f3;
bitset <M> c, d, f;
int n, nn, m;
int tot;
int a[N], b[N]; void calc_f0(){
rep(i, 1, n) b[i] = a[i];
sort(b + 1, b + n + 1); int cnt = unique(b + 1, b + n + 1) - b - 1;
tot = cnt;
rep(i, 1, n) a[i] = lower_bound(b + 1, b + cnt + 1, a[i]) - b;
f0 = 0ll + m - cnt;
f0 = 1ll * f0 * f0 * f0;
} void calc_f1(){
f1 = 1ll * m * m * m - f0 - f2 - f3;
} void calc_f2(){ f2 = 0;
d.reset();
f.reset(); rep(i, 1, n - 1){
rep(j, i + 1, n){
int x = a[i] * tot + a[j];
if (d[x]) continue;
d.set(x);
f2 += 0ll + m - tot;
rep(k, 1, tot){
int y = a[i] * tot * tot + a[j] * tot + k;
if (!c[y]) f.set(y);
}
}
} d.reset(); rep(i, 1, n - 1){
rep(j, i + 1, n){
int x = a[i] * tot + a[j];
if (d[x]) continue;
d.set(x);
f2 += 0ll + m - tot;
rep(k, 1, tot){
int y = k * tot * tot + a[i] * tot + a[j];
if (!c[y]) f.set(y);
}
}
} d.reset(); rep(i, 1, n - 1){
rep(j, i + 1, n){
int x = a[i] * tot + a[j];
if (d[x]) continue;
d.set(x);
f2 += 0ll + m - tot;
rep(k, 1, tot){
int y = a[i] * tot * tot + k * tot + a[j];
if (!c[y]) f.set(y);
}
}
} f2 += 0ll + f.count();
} void calc_f3(){
int cnt = 0;
c.reset();
rep(i, 1, n - 2){
rep(j, i + 1, n - 1){
rep(k, j + 1, n){
int x = a[i] * tot * tot + a[j] * tot + a[k];
c.set(x);
}
}
} f3 = c.count();
} int main(){ while (~scanf("%d%d", &n, &m)){
nn = n;
n = 0;
rep(i, 1, nn){
int x;
scanf("%d", &x);
if (x >= 1 && x <= m) a[++n] = x;
} calc_f0();
calc_f3();
calc_f2();
calc_f1(); printf("%lld %lld %lld %lld\n", f0, f1, f2, f3);
} return 0;
}
Problem G
Problem H
Problem I
Problem J
2017 CCPC 湘潭邀请赛的更多相关文章
- 2018 CCPC 湘潭邀请赛 & 2018 JSCPC
Problem A Problem B Problem C 这题用主席树轻松解决 可以二分答案,每次查询:也可以直接开个全局变量在主席树上二分: 时间复杂度$O(nlog^{2}n)$或$O(nlog ...
- 2017年 湘潭邀请赛(湖南)or 江苏省赛
这套题是叉姐出的,好难啊,先扫一遍好像没有会做的题了,仔细一想好像D最容易哎 Super Resolution Accepted : 112 Submit : 178 Time Limit : 1 ...
- ccpc湘潭邀请赛 Partial Sum
选定最多m的区间,使区间和的绝对值最大.但是左右端点不能重复选取 首先涉及到区间和的问题,就应该想到用前缀和去优化 这里对前缀和排序 然后贪心的去选取最大.次大 (比赛的时候脑子堵的很,没想出来 可惜 ...
- XTU 1264 - Partial Sum - [2017湘潭邀请赛E题(江苏省赛)]
2017江苏省赛的E题,当时在场上看错了题目没做出来,现在补一下…… 题目链接:http://202.197.224.59/OnlineJudge2/index.php/Problem/read/id ...
- 湘潭邀请赛+蓝桥国赛总结暨ACM退役总结
湘潭邀请赛已经过去三个星期,蓝桥也在上个星期结束,今天也是时候写一下总结了,这应该也是我的退役总结了~ --------------------------------湘潭邀请赛----------- ...
- 1250 Super Fast Fourier Transform(湘潭邀请赛 暴力 思维)
湘潭邀请赛的一题,名字叫"超级FFT"最终暴力就行,还是思维不够灵活,要吸取教训. 由于每组数据总量只有1e5这个级别,和不超过1e6,故先预处理再暴力即可. #include&l ...
- 湘潭邀请赛 Hamiltonian Path
湘潭邀请赛的C题,哈密顿路径,边为有向且给定的所有边起点小于终点,怎么感觉是脑筋急转弯? 以后一定要牢记思维活跃一点,把复杂的事情尽量简单化而不是简单的事情复杂化. #include<cstdi ...
- 2017 ccpc哈尔滨 A题 Palindrome
2017 ccpc哈尔滨 A题 Palindrome 题意: 给一个串\(T\),计算存在多少子串S满足\(S[i]=S[2n−i]=S[2n+i−2](1≤i≤n)\) 思路: 很明显这里的回文串长 ...
- HDU 6271 Master of Connected Component(2017 CCPC 杭州 H题,树分块 + 并查集的撤销)
题目链接 2017 CCPC Hangzhou Problem H 思路:对树进行分块.把第一棵树分成$\sqrt{n}$块,第二棵树也分成$\sqrt{n}$块. 分块的时候满足每个块是一个 ...
随机推荐
- 《Cracking the Coding Interview》——第1章:数组和字符串——题目3
2014-03-18 01:32 题目:对于两个字符串,判断它们是否是Anagrams. 解法:统计俩单词字母构成是否相同即可. 代码: // 1.3 Given two strings, write ...
- USACO Section1.5 Prime Palindromes 解题报告
pprime解题报告 —— icedream61 博客园(转载请注明出处)--------------------------------------------------------------- ...
- Python lambda介绍
在学习python的过程中,lambda的语法时常会使人感到困惑,lambda是什么,为什么要使用lambda,是不是必须使用lambda? 下面就上面的问题进行一下解答. 1.lambda是什么? ...
- SecureCRT自动登录跳板机/堡垒机并连接目标机器
公司登录目标服务器,需要先登录跳板机(堡垒机),然后再登录目标机器,一共需要4.5步. MAC或LINUX机器可以写.SH脚本,那WINDOWS有没有一键登陆的方法呢? 常用的SecureCRT工具就 ...
- Django 运行 端口被占用 Error: That port is already in use
本来运行项目:python manage.py runserver 8000 发现运行到结果报错: Error: That port is already in use 首先查看已存在端口号列表: $ ...
- C++ Programming with TDD之一:GMOCK框架简介
所谓测试驱动开发,英文全称Test-Driven Development,简称TDD,是一种不同于传统软件开发流程的新型的开发方法.就是在明确要开发某个功能后,首先思考如何对这个功能进行测试,并完成测 ...
- BZOJ 2730:[HNOI2012]矿场搭建(割点+连通块)
[HNOI2012]矿场搭建 Description 煤矿工地可以看成是由隧道连接挖煤点组成的无向图.为安全起见,希望在工地发生事故时所有挖煤点的工人都能有一条出路逃到救援出口处.于是矿主决定在某些挖 ...
- 【bzoj2793】[Poi2012]Vouchers 暴力
题目描述 考虑正整数集合,现在有n组人依次来取数,假设第i组来了x人,他们每个取的数一定是x的倍数,并且是还剩下的最小的x个.正整数中有m个数被标成了幸运数,问有哪些人取到了幸运数. 输入 第一行一个 ...
- 比较运算符compareTo()、equals()、==之间的区别与应用总结
在函数中定义的一些基本类型的变量和对象的引用变量都是在函数的栈内存中分配.当在一段代码块中定义一个变量时,java就在栈中为这个变量分配内存空间,当超过变量的作用域后,java会自动释放掉为该变量分配 ...
- Java中方法的重写与成员变量的隐藏
这篇文章讨论了Java面向对象概念中一个基本的概念–Field Hiding(隐藏成员变量) 在讨论这个问题之前,我们看一段特别特别简单的代码,请问一下方法的数据结果是什么? public class ...