题目链接  2013杭州区域赛

Problem A

Problem B

这题我用的是SPFA+ mask dp

首先跑5次SPFA:

1次是求出每个起点和其他所有点的最短距离

4次是求出每个输入的点和其他所有点的最短距离

然后就是dp

设dp[mask][i]为,mask状态下,以i为终点的最优方案
然后做一遍状压DP即可。

#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 = 103;
const int M = 1e4 + 10;
const int dx[] = {1, 0, -1, 0};
const int dy[] = {0, 1, 0, -1}; bool inqueue[M], fl;
int c[N][N], f[6][6], a[M], d[M], dp[101][6];
char s[N][N];
int cnt, n, m, k;
vector <int> v[M]; inline void addedge(int x, int y){
v[x].push_back(y);
v[y].push_back(x);
} void SPFA(int s){
memset(inqueue, false, sizeof inqueue);
rep(i, 1, cnt) d[i] = 1 << 29;
d[s] = 0;
queue <int> q;
q.push(s); while (!q.empty()){
int x = q.front();
q.pop();
inqueue[x] = false;
for (auto u : v[x]){
if (d[u] > d[x] + 1){
d[u] = d[x] + 1;
if (!inqueue[u]){
inqueue[u] = true;
q.push(u);
}
}
}
}
} int main(){ while (~scanf("%d%d", &n, &m), n + m){
rep(i, 1, n) scanf("%s", s[i] + 1);
cnt = 0;
rep(i, 1, n) rep(j, 1, m) c[i][j] = ++cnt; scanf("%d", &k);
rep(i, 1, n) rep(j, 1, m) if (s[i][j] == '@'){
a[k] = c[i][j];
s[i][j] = '.';
break;
} rep(i, 0, k - 1){
int x, y;
scanf("%d%d", &x, &y);
a[i] = c[x][y];
} rep(i, 0, n * m + 1) v[i].clear(); rep(i, 1, n){
rep(j, 1, m) if (s[i][j] == '.'){
rep(k, 0, 3){
int x = i + dx[k], y = j + dy[k];
if (s[x][y] == '.'){
addedge(c[i][j], c[x][y]);
}
}
}
} SPFA(a[k]); rep(i, 0, k) rep(j, 0, k) f[i][j] = 1 << 29;
rep(i, 0, k){
SPFA(a[i]);
rep(j, 0, k) if (i == j) f[i][j] = 0;
else f[i][j] = d[a[j]];
} rep(i, 0, 53) rep(j, 0, 5) dp[i][j] = 1 << 29;
rep(i, 0, k - 1) dp[1 << i][i] = f[i][k]; rep(i, 1, ((1 << k) - 1)){
if (__builtin_popcount(i) != 1){
rep(j, 0, k - 1) if ((i >> j) & 1){
rep(l, 0, k - 1) if (((i >> l) & 1) && (j != l)){
dp[i][j] = min(dp[i][j], dp[i ^ (1 << j)][l] + f[j][l]);
}
}
}
} int ans = 1 << 30;
rep(i, 0, k - 1) ans = min(ans, dp[(1 << k) - 1][i]);
printf("%d\n", ans < 1e6 ? ans : -1);
} return 0;
}

Problem C

跟着题意模拟一遍

关键是那个旋转要一次性写对

#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 = 41; int a[N][N], b[N][N];
int n;
int ans; void solve(){
int c[N][N]; memset(c, 0, sizeof c);
rep(i, 1, n) rep(j, 1, n) c[i][j] = a[j][n - i + 1];
rep(i, 1, n) rep(j, 1, n) a[i][j] = c[i][j];
} int main(){ while (~scanf("%d", &n), n){
rep(i, 1, n) rep(j, 1, n) scanf("%d", &a[i][j]);
rep(i, 1, n) rep(j, 1, n) scanf("%d", &b[i][j]); ans = 0;
rep(p, 1, 4){
solve();
int now = 0;
rep(i, 1, n) rep(j, 1, n) if (a[i][j] == b[i][j]) ++now;
ans = max(ans, now);
} printf("%d\n", ans);
} return 0;
}

Problem D

Problem E

Problem F

Problem G

Problem H

Problem I

Problem J

Problem K

2013 ACM/ICPC 亚洲区 杭州站的更多相关文章

  1. 2016 ACM/ICPC亚洲区青岛站现场赛(部分题解)

    摘要 本文主要列举并求解了2016 ACM/ICPC亚洲区青岛站现场赛的部分真题,着重介绍了各个题目的解题思路,结合详细的AC代码,意在熟悉青岛赛区的出题策略,以备战2018青岛站现场赛. HDU 5 ...

  2. 2016 ACM/ICPC亚洲区大连站-重现赛 解题报告

    任意门:http://acm.hdu.edu.cn/showproblem.php?pid=5979 按AC顺序: I - Convex Time limit    1000 ms Memory li ...

  3. 2016 ACM/ICPC亚洲区大连站 F - Detachment 【维护前缀积、前缀和、二分搜索优化】

    F - Detachment In a highly developed alien society, the habitats are almost infinite dimensional spa ...

  4. 2012 ACM/ICPC 亚洲区 金华站

    题目链接  2012金华区域赛 Problem A 按a/b从小到大的顺序排队进行体检即可 #include<iostream> #include<cstdio> #inclu ...

  5. 2016 ACM/ICPC亚洲区青岛站

    A B C D E F G H I J K L M O O O O     $\varnothing$     $\varnothing$  $\varnothing$  $\varnothing$  ...

  6. 2016 ACM/ICPC亚洲区沈阳站

    A B C D E F G H I J K L M O O O $\varnothing$ $\varnothing$   $\varnothing$ $\varnothing$ $\varnothi ...

  7. (HDU 5558) 2015ACM/ICPC亚洲区合肥站---Alice's Classified Message(后缀数组)

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=5558 Problem Description Alice wants to send a classi ...

  8. 2013ACM/ICPC亚洲区南京站现场赛---Poor Warehouse Keeper(贪心)

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=4803 Problem Description Jenny is a warehouse keeper. ...

  9. HDU 5950 Recursive sequence 【递推+矩阵快速幂】 (2016ACM/ICPC亚洲区沈阳站)

    Recursive sequence Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Other ...

随机推荐

  1. python3 发邮件 smtplib & email 库

    嗨 实现了用163发送到qq的功能,遗留了两个问题: 1. 接收者list会报错:update:因为list[]会传递过去一个真的[]list,改成如下就可以了: before: maillist=[ ...

  2. Python9-网络编程4-day33

    解决黏包问题: 在传输大量数据之前,先告诉接收端要发送数据大小 如果想更漂亮的解决问题,可以通过struct模块来定制协议为什么会出现黏包现象: 首先只有在tcp协议中才会出现黏包现象 是因为tcp协 ...

  3. Linux下的硬件驱动——USB设备(转载)

    usb_bulk_msg函数 当对usb设备进行一次读或者写时,usb_bulk_msg 函数是非常有用的; 然而, 当你需要连续地对设备进行读/写时,建议你建立一个自己的urbs,同时将urbs 提 ...

  4. 【HIHOCODER 1181】欧拉路·二

    描述 在上一回中小Hi和小Ho控制着主角收集了分散在各个木桥上的道具,这些道具其实是一块一块骨牌. 主角继续往前走,面前出现了一座石桥,石桥的尽头有一道火焰墙,似乎无法通过. 小Hi注意到在桥头有一张 ...

  5. python基础学习笔记——类的约束

    ⾸先, 你要清楚. 约束是对类的约束. 用一个例子说话: 公司让小明给他们的网站完善一个支付功能,小明写了两个类,如下: class QQpay: def pay(self,money): print ...

  6. dataTable组件使用

    dataTable组件使用:引入JS $("#id").DataTable({ scrollY:450,    //开始滚动高度 lengthChange:false ,   // ...

  7. 贪心 - [POI2006]ORK-Ploughing

    [POI2006]ORK-Ploughing 描述 Byteasar 想耕种他那块矩形的田,他每次能耕种矩形的一边(上下左右都行),在他每次耕完后,剩下的田也一定是矩形,每块小区域边长为 1,耕地的长 ...

  8. NHibernate N+1问题实例分析和优化

    1.问题的缘起 考察下面的类结构定义 public class Category { string _id; Category _parent; IList<Category> _chil ...

  9. jade和ejs两者的特点

    jade特点 1超强的可读性 2灵活易用的缩进 3块扩展 4代码默认进过编码处理,以增强安全性 5编译及运行时的上下文错误报告 6命令行编译支持 7html5模式(使用 !!!5文档类型) 8可选的内 ...

  10. POJ 1315 Don't Get Rooked

    Don't Get Rooked Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 2086   Accepted: 1325 ...