Codeforces Round #345 (Div. 2)
DFS A - Joysticks
嫌麻烦直接DFS暴搜吧,有坑点是当前电量<=1就不能再掉电,直接结束。
#include <bits/stdc++.h> typedef long long ll;
const int N = 1e5 + 5;
int ans = 0; void DFS(int a, int b, int step) {
if (a <= 0 || b <= 0) {
ans = std::max (ans, step); return ;
}
if (a < b && b - 2 >= 0) {
DFS (a + 1, b - 2, step + 1);
} else if (a >= b && a - 2 >= 0) {
DFS (a - 2, b + 1, step + 1);
}
} int main() {
int a, b; std::cin >> a >> b;
ans = 0;
DFS (a, b, 0);
std::cout << ans << '\n'; return 0;
}
构造 + 贪心 B - Beautiful Paintings
每次取出不重复的递增序列,直到集合为空
#include <bits/stdc++.h> typedef long long ll;
const int N = 1e5 + 5;
std::vector<int> vec; int main() {
int n; std::cin >> n;
for (int x, i=0; i<n; ++i) {
std::cin >> x; vec.push_back (x);
}
std::sort (vec.begin (), vec.end ());
int ans = 0;
while (vec.size () > 0) {
std::vector<int> tmp;
int pre = 0, num = 0;
for (auto x: vec) {
if (x > pre) {
num++; pre = x;
} else {
tmp.push_back (x);
}
}
ans += num - 1; vec = tmp;
}
std::cout << ans << '\n'; return 0;
}
数学 + 容斥 C - Watchmen
化简公式得到找到pair (i, j) xi == xj || yi == yj。找两次再容斥一下。map做更好。
#include <bits/stdc++.h> typedef long long ll;
const int N = 2e5 + 5;
const int INF = 1e9 + 7;
std::pair<int, int> point[N]; ll calc(int n) {
return 1ll * n * (n - 1) / 2;
} bool cmpx(std::pair<int, int> a, std::pair<int, int> b) {
return a.first < b.first;
} bool cmpy(std::pair<int, int> a, std::pair<int, int> b) {
return a.second < b.second;
}
int main() {
int n; scanf ("%d", &n);
for (int x, y, i=0; i<n; ++i) {
scanf ("%d%d", &x, &y);
point[i] = std::make_pair (x, y);
}
std::sort (point, point+n, cmpx);
ll ans = 0;
int x = INF, y = INF, num = 1;
for (int i=0; i<n; ++i) {
if (x == point[i].first) {
num++;
} else {
x = point[i].first;
if (num > 1) {
ans += calc (num);
}
num = 1;
}
}
if (num > 1) {
ans += calc (num);
}
std::sort (point, point+n, cmpy);
x = INF; y = INF; num = 1;
for (int i=0; i<n; ++i) {
if (y == point[i].second) {
num++;
} else {
y = point[i].second;
if (num > 1) {
ans += calc (num);
}
num = 1;
}
}
if (num > 1) {
ans += calc (num);
}
std::sort (point, point+n);
x = INF; y = INF; num = 1;
for (int i=0; i<n; ++i) {
if (x == point[i].first && y == point[i].second) {
num++;
} else {
x = point[i].first, y = point[i].second;
if (num > 1) {
ans -= calc (num);
}
num = 1;
}
}
if (num > 1) {
ans -= calc (num);
}
printf ("%I64d\n", ans); return 0;
}
two points D - Image Preview
题意:浏览图片,浏览,滑动以及反转需要时间,问在T时间内最多浏览多少图片。
分析:定义两个指针from,to,可行的方案是n+1->from,from->n+1,n+1->to或者n+1->to,to->n+1,n+1->from,还有from->to。前两个重复滑动的可以选择距离小的,第三个只要定义to=n+1就对了。其实可以用二分做的。
#include <bits/stdc++.h> typedef long long ll;
const int N = 5e5 + 5;
char str[2*N];
ll tim[2*N];
int n, a, b, T; ll get_time(int from, int to) {
ll ret = tim[from] - tim[to-1];
int move = from - to + std::min (from-(n+1), (n+1)-to);
return ret + 1ll * a * move;
} int main() {
scanf ("%d%d%d%d", &n, &a, &b, &T);
scanf ("%s", str + 1);
for (int i=1; i<=n; ++i) {
tim[i] = (str[i] == 'w' ? (b+1) : 1);
}
for (int i=n+1; i<=2*n; ++i) {
tim[i] = tim[i-n];
}
for (int i=1; i<=2*n; ++i) {
tim[i] += tim[i-1];
}
int ans = 0;
int from = n + 1;
for (int to=2; to<=n+1; ++to) {
while (from < to+n-1 && get_time (from+1, to) <= T) from++;
if (get_time (from, to) <= T) ans = std::max (ans, from - to + 1);
}
printf ("%d\n", ans); return 0;
}
图论 + 并查集 E - Table Compression
题意:给一个矩阵,求新的矩阵,使得原矩阵的同行,同列的大小关系不变,且使得新矩阵的最大值最小。即离散化
分析:找好顺序,一个一个从小到大填充就行了。因为有相同数字的存在,使用并查集使得将相同的数字赋值离散化后相同的数字。因为有行和列共同影响一个数字,所以建立一个大数到小数的图,类似树形DP,选择当前行或列的最大值+1为离散化后的数字
#include <bits/stdc++.h> const int N = 1e6 + 5;
std::pair<int, std::pair<int, int> > A[N];
int val[N], ans[N];
int mr[N], mc[N];
int rt[N];
std::vector<int> edge[N];
std::vector<int> num[N]; int Find(int x) {
return rt[x] == x ? x : rt[x] = Find (rt[x]);
} int main() {
int n, m; scanf ("%d%d", &n, &m);
int tot = n * m;
for (int i=0; i<n; ++i) {
for (int j=0; j<m; ++j) {
scanf ("%d", &val[i*m+j]);
A[i*m+j].first = val[i*m+j];
A[i*m+j].second = std::make_pair (i, j);
rt[i*m+j] = i * m + j;
}
}
std::fill (mr, mr+n, -1);
std::fill (mc, mc+m, -1);
std::sort (A, A+tot);
for (int i=0; i<tot; ++i) {
int r = A[i].second.first, c = A[i].second.second;
int pos = r * m + c;
if (mr[r] != -1) {
if (val[mr[r]] == A[i].first) {
rt[pos] = Find (mr[r]);
} else {
edge[pos].push_back (mr[r]);
}
}
if (mc[c] != -1) {
if (val[mc[c]] == A[i].first) {
rt[Find (pos)] = Find (mc[c]);
} else {
edge[pos].push_back (mc[c]);
}
}
mr[r] = mc[c] = pos;
}
for (int i=0; i<tot; ++i) {
num[Find (i)].push_back (i);
}
for (int i=0; i<tot; ++i) {
int r = A[i].second.first, c = A[i].second.second;
int id = r * m + c;
if (Find (id) == id) {
int _max = 0;
for (auto u: num[id]) {
for (auto v: edge[u]) {
_max = std::max (_max, ans[v]);
}
}
for (auto u: num[id]) {
ans[u] = _max + 1;
}
}
}
for (int i=0; i<n; ++i) {
for (int j=0; j<m; ++j) {
printf ("%d ", ans[i*m+j]);
}
puts ("");
} return 0;
}
Codeforces Round #345 (Div. 2)的更多相关文章
- cf之路,1,Codeforces Round #345 (Div. 2)
		cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅..... ... 
- Codeforces Round #345 (Div. 2)【A.模拟,B,暴力,C,STL,容斥原理】
		A. Joysticks time limit per test:1 second memory limit per test:256 megabytes input:standard input o ... 
- Codeforces Round #345 (Div. 1) C. Table Compression dp+并查集
		题目链接: http://codeforces.com/problemset/problem/650/C C. Table Compression time limit per test4 secon ... 
- Codeforces Round #345 (Div. 1) E. Clockwork Bomb 并查集
		E. Clockwork Bomb 题目连接: http://www.codeforces.com/contest/650/problem/E Description My name is James ... 
- Codeforces Round #345 (Div. 1) D. Zip-line 上升子序列 离线 离散化 线段树
		D. Zip-line 题目连接: http://www.codeforces.com/contest/650/problem/D Description Vasya has decided to b ... 
- Codeforces Round #345 (Div. 2) E. Table Compression 并查集
		E. Table Compression 题目连接: http://www.codeforces.com/contest/651/problem/E Description Little Petya ... 
- Codeforces Round #345 (Div. 2) D. Image Preview 暴力 二分
		D. Image Preview 题目连接: http://www.codeforces.com/contest/651/problem/D Description Vasya's telephone ... 
- Codeforces Round #345 (Div. 1) A - Watchmen 容斥
		C. Watchmen 题目连接: http://www.codeforces.com/contest/651/problem/C Description Watchmen are in a dang ... 
- Codeforces Round #345 (Div. 2) B. Beautiful Paintings 暴力
		B. Beautiful Paintings 题目连接: http://www.codeforces.com/contest/651/problem/B Description There are n ... 
- Codeforces Round #345 (Div. 2) A. Joysticks dp
		A. Joysticks 题目连接: http://www.codeforces.com/contest/651/problem/A Description Friends are going to ... 
随机推荐
- IOS - 本地消息推送
			第一步:创建本地推送 // 创建一个本地推送 UILocalNotification *notification = [[[UILocalNotification alloc] init] autor ... 
- PHP工厂模式的研究
			工厂方法模式 把 创造者类 和要生产的 产品类 分离.创建者是一个工厂类,其定义了产品生产的类方法.一般情况下,创建者类的每个子类实例化一个相应的产品子类. 下面是单个产品的实现代码: <?ph ... 
- July 6th, Week 28th Wednesday, 2016
			Diligence is the mother of good fortune. 勤勉是好运之母. The mother of good fortune can be diligence, conti ... 
- mongoose学习笔记1--基础知识1
			今天我们将学习Mongoose,什么是Mongoose呢,它于MongoDB又是什么关系呢,它可以用来做什么呢? MongoDB是一个开源的NoSQL数据库,相比MySQL那样的关系型数据库,它更显得 ... 
- python基础——使用@property
			python基础——使用@property 在绑定属性时,如果我们直接把属性暴露出去,虽然写起来很简单,但是,没办法检查参数,导致可以把成绩随便改: s = Student() s.score = 9 ... 
- Java大数处理类:BigInteger类和BigDecimal类
			当我们要处理非常大的数据时,平常用的数据类型已不足以表示,在Java中有两个类BigInteger和BigDecimal分别表示大整数类和大浮点数类,这两个类在理论上只要计算机内存足够大就能够表示无线 ... 
- 关于logcat日志
			最近学习android,碰到了logcat,个人总结一下. 当不出日志是解决办法: ProjectMenu---后台设置----LOG设置---LOG开关 Logcat(deprecated)和Log ... 
- Jmeter中通过BeanShell获取当前时间
			第一步编写需要的java类: 第二步:将编写好的java类打包成jar包 第三步:将jar包放到\apache-jmeter-2.13\lib\ext下面 第四步:在Jmeter中通过BeanShel ... 
- SQLServer基本查询
			条件查询 --1.比较运算符 --2.确定集合谓词 --3.确定范围谓词 , ) --4.字符匹配谓词 select * from dbo.DepartMent where dName like 'C ... 
- js自定义延迟执行函数
			<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ... 
