The 2014 ACM-ICPC Asia Mudanjiang Regional Contest(2014牡丹江区域赛)
The 2014 ACM-ICPC Asia Mudanjiang Regional Contest
没去现场。做的网络同步赛。感觉还能够,搞了6题
A:这是签到题,对于A堆除掉。假设没剩余在减一。B堆直接除掉 + 1就能够了
B:二分贪心,二分长度。然后会发现本质上是在树上最长链上找两点,那么有二分出来的长度了,就从两端分别往里移动那么长,那两个位置就是放置位置。然后在推断一下就能够了
D:概率DP。首先知道放一个棋子。能够等价移动到右上角区域,那么就能够dp[x][y][k],表示已经完毕x行y列。已经放了k个棋子,那么棋盘被划分成4个区域。利用这个区域能够算概率,然后去转移就可以
H:字符串处理,先hash掉,记录每一个hash值相应的l,r区间。离线处理完每次询问输出就能够了,注意细节
I:签到题,注意0的时候是等于0就能够了
K:贪心,假设数字个数不够。在前面补是最优的。然后从左往右扫描一遍,每次遇到1个星号要扣掉两个数字,假设没有,这须要交换操作。交换肯定和最后面的数字交换是最优的,最后还要考虑一种特殊情况。就是没有交换,而且最后还有数字,这时候要加入一个星号
代码:
A:
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std; const int N = 55;
int t, n, m; int a, b, suma, sumb; int main() {
scanf("%d", &t);
while (t--) {
scanf("%d%d", &n, &m);
suma = sumb = 0;
for (int i = 0; i < n - 1; i++) {
scanf("%d", &a);
suma += a;
}
for (int i = 0; i < m; i++) {
scanf("%d", &b);
sumb += b;
}
int l, r;
l = suma / (n - 1) - (suma % (n - 1) == 0);
r = sumb / m + 1;
if (l > r) swap(l, r);
printf("%d %d\n", l, r);
}
return 0;
}
B:
#include <cstdio>
#include <cstring>
#include <queue>
#include <algorithm>
using namespace std; const int N = 200005; struct Edge {
int u, v;
Edge() {}
Edge(int u, int v) {
this->u = u;
this->v = v;
}
} E[N * 2]; int first[N], next[N * 2], en; void add_Edge(int u, int v) {
E[en] = Edge(u, v);
next[en] = first[u];
first[u] = en++;
} const int INF = 0x3f3f3f3f;
int t, n, vis[N], f[N], u1, u2, Q[N * 2]; int bfs(int root) {
int head = 0, rear = 0;
vis[root] = 0;
Q[rear++] = root;
f[root] = 0;
int u;
while (head < rear) {
u = Q[head++];
for (int i = first[u]; i + 1; i = next[i]) {
Edge e = E[i];
int v = e.v;
if (vis[v] > vis[u] + 1) {
vis[v] = vis[u] + 1;
f[v] = u;
Q[rear++] = v;
}
}
}
return u;
} bool judge(int len) {
memset(vis, INF, sizeof(vis));
u1 = bfs(1);
for (int i = 0; i < len; i++) {
if (f[u1] == 0) {
u2 = u1 % n + 1;
return true;
}
u1 = f[u1];
}
memset(vis, INF, sizeof(vis));
u2 = bfs(u1);
for (int i = 0; i < len; i++) {
if (f[u2] == 0) return true;
u2 = f[u2];
}
bfs(u2);
for (int i = 1; i <= n; i++)
if (vis[i] > len) return false;
return true;
} int main() {
scanf("%d", &t);
while (t--) {
en = 0;
memset(first, -1, sizeof(first));
scanf("%d", &n);
int u, v;
for (int i = 1; i < n; i++) {
scanf("%d%d", &u, &v);
add_Edge(u, v);
add_Edge(v, u);
}
if (n == 2) {
printf("0 1 2\n");
continue;
}
int l = 0, r = n;
while (l < r) {
int mid = (l + r) / 2;
if (judge(mid)) r = mid;
else l = mid + 1;
}
judge(l);
if (u1 == u2) u2 = u2 % n + 1;
printf("%d %d %d\n", l, u1, u2);
}
return 0;
}
D:
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std; const int N = 55;
int t, n, m;
double dp[N][N][N * N]; int main() {
scanf("%d", &t);
while (t--) {
scanf("%d%d", &n, &m);
memset(dp, 0, sizeof(dp));
dp[0][0][0] = 1;
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= m; j++) {
for (int k = max(i, j); k <= i * j; k++) {
double p1 = (i * j - (k - 1)) * 1.0;
double p2 = (n - i + 1) * j;
double p3 = i * (m - j + 1);
double p4 = (n - i + 1) * (m - j + 1);
dp[i][j][k] = dp[i][j][k - 1] * p1 + dp[i - 1][j][k - 1] * p2 + dp[i][j - 1][k - 1] * p3 + dp[i - 1][j - 1][k - 1] * p4;
dp[i][j][k] /= (n * m - (k - 1));
}
}
}
double ans = 0;
for (int i = max(n, m); i <= n * m; i++)
ans += dp[n][m][i] * i - dp[n][m][i - 1] * i;
printf("%.12lf\n", ans);
}
return 0;
}
H:
#include <cstdio>
#include <cstring>
#include <map>
using namespace std; #define MP(a,b) make_pair(a,b) typedef unsigned long long ull;
const ull x = 123;
const int N = 200005;
typedef pair<int, int> pii; char str[N], q[N];
map<ull, pii> g; int t, u, k, lens; int build(ull st) {
int flag = 1;
while (u < lens) {
if (str[u] == '{') {
flag = 0;
u++;
}
if (str[u] == '}') {
u++;
return u;
}
ull nt = st;
while (str[u] != ':' && str[u] != ',' && str[u] != '}')
nt = nt * x + str[u++];
if (str[u] == ':') {
int l = ++u;
int r = build(nt * x + '.');
g[nt] = MP(l, r);
}
if (str[u] == '}') {
if (!flag)
u++;
return u;
}
if (str[u] == ',') {
if (flag) return u;
u++;
}
}
} int main() {
scanf("%d", &t);
while (t--) {
u = 0;
g.clear();
scanf("%s", str);
lens = strlen(str);
build(0);
scanf("%d", &k);
while (k--) {
scanf("%s", q);
ull tmp = 0;
int len = strlen(q);
for (int i = 0; i < len; i++)
tmp = tmp * x + q[i];
if (!g.count(tmp)) {
printf("Error!\n");
continue;
}
int l = g[tmp].first, r = g[tmp].second;
for (int i = l; i < r; i++)
printf("%c", str[i]);
printf("\n");
}
}
return 0;
}
I:
#include <cstdio>
#include <cstring>
#include <cmath> int t, n;
char str[10]; double solve(int x) {
if (x == 0) return 0;
double sb = x * 1.0 / 100;
if (str[0] == 'b') return sb * log2(sb);
if (str[0] == 'n') return sb * log(sb);
if (str[0] == 'd') return sb * log10(sb);
} int main() {
scanf("%d", &t);
while (t--) {
scanf("%d%s", &n, str);
double ans = 0;
int x;
for (int i = 0; i < n; i++) {
scanf("%d", &x);
ans += solve(x);
}
printf("%.12lf\n", -ans);
}
return 0;
}
K:
#include <cstdio>
#include <cstring>
#include <map>
using namespace std; #define MP(a,b) make_pair(a,b) typedef unsigned long long ull;
const ull x = 123;
const int N = 200005;
typedef pair<int, int> pii; char str[N], q[N];
map<ull, pii> g; int t, u, k, lens; int build(ull st) {
int flag = 1;
while (u < lens) {
if (str[u] == '{') {
flag = 0;
u++;
}
if (str[u] == '}') {
u++;
return u;
}
ull nt = st;
while (str[u] != ':' && str[u] != ',' && str[u] != '}')
nt = nt * x + str[u++];
if (str[u] == ':') {
int l = ++u;
int r = build(nt * x + '.');
g[nt] = MP(l, r);
}
if (str[u] == '}') {
if (!flag)
u++;
return u;
}
if (str[u] == ',') {
if (flag) return u;
u++;
}
}
} int main() {
scanf("%d", &t);
while (t--) {
u = 0;
g.clear();
scanf("%s", str);
lens = strlen(str);
build(0);
scanf("%d", &k);
while (k--) {
scanf("%s", q);
ull tmp = 0;
int len = strlen(q);
for (int i = 0; i < len; i++)
tmp = tmp * x + q[i];
if (!g.count(tmp)) {
printf("Error!\n");
continue;
}
int l = g[tmp].first, r = g[tmp].second;
for (int i = l; i < r; i++)
printf("%c", str[i]);
printf("\n");
}
}
return 0;
}
The 2014 ACM-ICPC Asia Mudanjiang Regional Contest(2014牡丹江区域赛)的更多相关文章
- hdu 5016 点分治(2014 ACM/ICPC Asia Regional Xi'an Online)
Mart Master II Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)T ...
- The 2014 ACM-ICPC Asia Mudanjiang Regional Contest
The 2014 ACM-ICPC Asia Mudanjiang Regional Contest A.Average Score B.Building Fire Stations C.Card G ...
- HDU 5000 2014 ACM/ICPC Asia Regional Anshan Online DP
Clone Time Limit : 2000/1000ms (Java/Other) Memory Limit : 65536/65536K (Java/Other) Total Submiss ...
- ACM ICPC Central Europe Regional Contest 2013 Jagiellonian University Kraków
ACM ICPC Central Europe Regional Contest 2013 Jagiellonian University Kraków Problem A: Rubik’s Rect ...
- 2019-2020 ICPC, Asia Jakarta Regional Contest (Online Mirror, ICPC Rules, Teams Preferred)
2019-2020 ICPC, Asia Jakarta Regional Contest (Online Mirror, ICPC Rules, Teams Preferred) easy: ACE ...
- The 2014 ACM-ICPC Asia Mudanjiang Regional Contest 【部分题解】
2014牡丹江亚洲区域赛邀请赛 B题:图论题目 题解:这里 K题:想法题 分析:两种变化.加入和交换.首先:星号是n的话最少须要的数字是n+1,那么能够首先推断数字够不够,不够的话如今最前面添数字,假 ...
- 2014 ACM/ICPC Asia Regional Shanghai Online
Tree http://acm.hdu.edu.cn/showproblem.php?pid=5044 树链剖分,区间更新的时候要用on的左++右--的标记方法,要手动扩栈,用c++交,综合以上的条件 ...
- HDU 5029 Relief grain(离线+线段树+启发式合并)(2014 ACM/ICPC Asia Regional Guangzhou Online)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5029 Problem Description The soil is cracking up beca ...
- 2014 ACM/ICPC Asia Regional Guangzhou Online
Wang Xifeng's Little Plot http://acm.hdu.edu.cn/showproblem.php?pid=5024 预处理出每个点八个方向能走的最远距离,然后枚举起点,枚 ...
随机推荐
- 请将你的App签名文件放进保险箱
这是一篇以我自己的实际经历写的一篇文章. 当下移动开发正值火爆,由于门槛低,任何一个程序员都可以比较容易的进入移动开发领域,作为App或者游戏等移动开发者,当你开发完成一个作品后,准备上线时,需要对你 ...
- python学习笔记(6)——字典(Dictionary)
dict= {key1 : value1, key2 : value2 ...} 关键词:字典中元素成对出现- key:value 格式- 两端{ } ,键:值,每对键值间用 ,隔开. 键key-唯一 ...
- Think PHP中URL_MODE相关事项
官网上有关于URL_MODE的解释:http://document.thinkphp.cn/manual_3_2.html#url 这里主要讲一下URL_MODE为2,即REWRITE模式. REWR ...
- ASP.NET跨页面传值技巧[总结]
个人网站:http://www.51pansou.com .net视频下载:.net视频教程 .net源码下载:.net源码 关于页面传值的方法,我就我个人观点做了些总结,希望对大家有所帮助. 1. ...
- 梦想iOS版CAD控件2018.11.07更新
下载地址: http://www.mxdraw.com/ndetail_10110.html 1. 增加iOS上的CAD绘图接口和使用例子 2. 增加动态交互使用例子 3. 把Android上改 ...
- 解决vue项目运行过程中,npm run dev 报错问题
[方案1] 错误如下: npm ERR! code ELIFECYCLE npm ERR! errno 1 npm ERR! travel@1.0.0 dev: `webpack-dev-server ...
- 实现加载页Loading Page 的几种方法
网页也可以像原生应用那样加入进度条或者其他的loading效果带来更好的等待体验,这里归纳几种我收集的实现loading page的方法,这几种方法在交互上都有利有弊,适用于不同应用.(PS:以下方法 ...
- 【转载】jxl的使用总结(java操作excel)
jxl.jar是通过java操作excel表格的工具类库: 链接:https://pan.baidu.com/s/1AAT_eA_Q47zFeQohap6eQg 提取码:777b 1:通过模拟实现创建 ...
- 面向对象程序设计--Java语言第二周编程题:有秒计时的数字时钟
有秒计时的数字时钟 题目内容: 这一周的编程题是需要你在课程所给的时钟程序的基础上修改而成.但是我们并不直接给你时钟程序的代码,请根据视频自己输入时钟程序的Display和Clock类的代码,然后来做 ...
- 用Java写一个生产者-消费者队列
生产者消费者的模型作用 通过平衡生产者的生产能力和消费者的消费能力来提升整个系统的运行效率,这是生产者消费者模型最重要的作用. 解耦,这是生产者消费者模型附带的作用,解耦意味着生产者和消费者之间的联系 ...