2013 Asia acm Hangzhou Regional Contest 杭州现场赛
B Stealing Harry Potter's Precious
题目大意:给定一个n*m的地图,某些点可以走,某些点可以走某些点不可以走,给定一个起点,又给出了k个点k<=4,要求从起点经过K个点最短的长度是多少
思路:给每个点标定状态为[x][y][state],state是压缩状态的已经走过需要走过点的集合,然后bfs一下即可
#include<cstdio>
#include<queue>
#include<cstring>
#define maxn 101
using namespace std;
const int dx[]={,,,,-};
const int dy[]={,,-,,};
int map[maxn][maxn],full,n,m,sx,sy,x,y,ma;
char ch[maxn];
struct T{int x;int y;int st;int dist;};
int cal(int x,int y){if(y<=)return x;return x|(<<(y-));}
bool visit[maxn][maxn][];
int bfs(int x,int y)
{
queue<T>q;T a;
a.x=x;a.y=y;a.st=cal(,map[x][y]);a.dist=;
visit[a.x][a.y][a.st]=;
q.push(a);
while(!q.empty())
{
T u=q.front();
q.pop();
for(int i=;i<=;i++)
{
int xx=u.x+dx[i],yy=u.y+dy[i];
if(xx<||xx>n||yy<||yy>m||map[xx][yy]==)continue;
T v;v.x=xx;v.y=yy;
v.st=cal(u.st,map[xx][yy]);
v.dist=u.dist+;
if(visit[v.x][v.y][v.st]==)continue;
visit[v.x][v.y][v.st]=;
if(v.st==full)
{
return v.dist;
}
q.push(v);
}
}
return -;
}
int main()
{
while(scanf("%d%d",&n,&m)!=EOF)
{
memset(visit,,sizeof(visit));
if(n== && m==)break;
for(int i=;i<=n;i++)
{
scanf("%s",ch+);
for(int j=;j<=m;j++)
{
if(ch[j]=='#')map[i][j]=;else map[i][j]=;
if(ch[j]=='@')sx=i,sy=j;
}
}
int k;
scanf("%d",&k);
full=(<<k)-;
for(int i=;i<=k;i++)
{
scanf("%d%d",&x,&y);
map[x][y]=i+;
}
printf("%d\n",bfs(sx,sy));
}
return ;
}
C - Zhuge Liang's Password
题目大意:给出两个矩阵,要求两个矩阵旋转之后的最大重合的数字个数
思路:直接模拟
#include<cstdio>
#include<queue>
#include<cstring>
#define maxn 101
using namespace std;
int a[maxn][maxn],n,b[maxn][maxn];
void rot(){
int c[maxn][maxn]={{}};
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)c[i][j]=a[j][n-i+];
memcpy(a,c,sizeof(a));
}
int main()
{
while(scanf("%d",&n)!=EOF){
if(n==)break;
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)scanf("%d",&a[i][j]);
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)scanf("%d",&b[i][j]);
int ans=;
for(int k=;k<=;k++){
int temp=;
rot();
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
if(a[i][j]==b[i][j])temp++;
ans=max(ans,temp);
}
printf("%d\n",ans);
}
return ;
}
2013 Asia acm Hangzhou Regional Contest 杭州现场赛的更多相关文章
- 2013杭州现场赛B题-Rabbit Kingdom
杭州现场赛的题.BFS+DFS #include <iostream> #include<cstdio> #include<cstring> #define inf ...
- 2016 ACM/ICPC亚洲区青岛站现场赛(部分题解)
摘要 本文主要列举并求解了2016 ACM/ICPC亚洲区青岛站现场赛的部分真题,着重介绍了各个题目的解题思路,结合详细的AC代码,意在熟悉青岛赛区的出题策略,以备战2018青岛站现场赛. HDU 5 ...
- ACM总结——2017ACM-ICPC北京赛区现场赛总结
现在距离比赛结束已经过了一个多星期了,也是终于有时间写下心得了.回来就是被压着做项目,也是够够的. 这次比赛一样是我和两个学弟(虽然是学弟,但我的实力才是最弱的T_T)一起参加的,成绩的话打铁,算是情 ...
- 2013 Asia Hangzhou Regional Contest
Lights Against Dudely http://acm.hdu.edu.cn/showproblem.php?pid=4770 15个位置,所以可以暴力枚举那些放,对于放的再暴力枚举哪个转, ...
- HDU4771(2013 Asia Hangzhou Regional Contest )
http://acm.hdu.edu.cn/showproblem.php?pid=4771 题目大意: 给你一幅图(N*M)“@”是起点,"#"是墙,“.”是路,然后图上有K个珠 ...
- 2013 Asia Hangzhou Regional Contest hdu4780 Candy Factory
参考:https://blog.csdn.net/sd_invol/article/details/15813671 要点 每个任务的结束时间是固定的,不受任何因素影响 机器只在最一开始有用,在那之后 ...
- 2012 Asia Hangzhou Regional Contest
Friend Chains http://acm.hdu.edu.cn/showproblem.php?pid=4460 图的最远两点距离,任意选个点bfs,如果有不能到的点直接-1.然后对于所有距离 ...
- HDU 3685 Rotational Painting(多边形质心+凸包)(2010 Asia Hangzhou Regional Contest)
Problem Description Josh Lyman is a gifted painter. One of his great works is a glass painting. He c ...
- HDU 3686 Traffic Real Time Query System(双连通分量缩点+LCA)(2010 Asia Hangzhou Regional Contest)
Problem Description City C is really a nightmare of all drivers for its traffic jams. To solve the t ...
随机推荐
- Android项目中包名的修改
通常修改包名时会造成R文件错误,并且有时带有原因不明的Manifest文件中多处文本混乱. 所以,将目前认为最为简洁方便的修改包名流程记录如下: 假设我们目前的包名为com.pepper.util,我 ...
- APP弱网测试点
- sqlserver 视图用 case when
视图用 case when 需要 用如下格式,[需要的列名]= case when...,而表里面的case 不用这样 [isNormal]=CASE WHENdbo.c_bdm_head.I_E_F ...
- LeetCode 最长连续递增序列
给定一个未经排序的整数数组,找到最长且连续的的递增序列. 示例 1: 输入: [1,3,5,4,7] 输出: 3 解释: 最长连续递增序列是 [1,3,5], 长度为3. 尽管 [1,3,5,7] 也 ...
- luogu P1966 火柴排队 (逆序对)
luogu P1966 火柴排队 题目链接:https://www.luogu.org/problemnew/show/P1966 显然贪心的想,排名一样的数相减是最优的. 证明也很简单. 此处就不证 ...
- 如何用纯 CSS 绘制一个充满动感的 Vue logo
效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/zaqKPx 可交互视频教 ...
- 气泡小角的css实现
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml" dir="ltr"> ...
- CSS3的背景background
CSS3中的Background属性 background: background-image || background-position/background-size || background ...
- sql 表连接的3种类型
内连接 inner join (join) 交叉连接 cross join 笛卡尔积 效率低 外连接 outer join (left join ,right join ,full join ...
- python计算机基础(一)
什么是编程语言? 跟计算机交流的语言 什么是编程? 编程就是写代码,让计算机能够听懂的语言 为什么要编程? 让计算机为我们做事,取代人 计算机5大组成分别有什么作用? CPU:控制,判断,配作用,内存 ...