暑假小训练 (一道 不能不会的用结构体搜索题)
来源:互联网 发布:gps nema数据 编辑:程序博客网 时间:2024/06/01 07:21
http://acm.hust.edu.cn/vjudge/contest/129524#problem/I
题意:8x8的象棋,给出开始和结束的点,和一个不能走的点,求出最短路。
#include<iostream>#include<cstdio>#include<cstring>#include<queue>using namespace std;int ax,ay,bx,by,cx,cy;int gragh[10][10];int path[10][10];class Map //用结构体可以方便的判断x,y{public: int x,y;}now;void bfs(){ now.x = ax; now.y = ay; queue<Map>q; q.push(now); while(!q.empty()){ Map a = q.front(); q.pop(); if(a.x == bx && a.y == by) return ; for(int i = -1;i <= 1; i++) for(int j = -1;j <= 1; j++) if(i != 0 || j != 0){ if(a.x+i <= 8 && a.x+i >= 1 && a.y+j <= 8 && a.y+j >= 1 && gragh[a.x+i][a.y+j] != -1 && path[a.x+i][a.y+j] == 0) { //分别判断了:界,不是c点,没走过 Map temp; temp.x = a.x+i; temp.y = a.y+j; path[temp.x][temp.y] = path[a.x][a.y]+1; q.push(temp); } } }}int main(){ int ncase = 1;// freopen("in.txt","r",stdin); while(scanf("%d%d%d%d%d%d",&ax,&ay,&bx,&by,&cx,&cy) != EOF){ memset(path,0,sizeof(path)); memset(gragh,0,sizeof(gragh)); //记得初始化 gragh[cx][cy] = -1; bfs(); printf("Case %d: %d\n",ncase++,path[bx][by]); } return 0;}
0 0
- 暑假小训练 (一道 不能不会的用结构体搜索题)
- 暑假训练1-搜索专题
- 暑假培训选拔赛的一道题
- 寒假训练的一道题:
- 暑假训练(一) 通过的题目
- 暑假训练(二) 等待的题目
- 暑假集训--训练1 二分搜索
- ACM暑假训练第3场中石油集训题(记忆化搜索,dp,树状数组)
- 2017暑假训练国庆小假期总结
- 擅长排列的小明,,,(第一道真正意义上的搜索)
- 一道小的算法题
- 一道自动机的小题
- 真的不会做搜索题!!!!!!!!!!!!!
- ACM暑假训练题单
- 一道小题(2)
- 一道小题(3)
- CSU-ACM2016暑假集训训练1-二分搜索-C
- 一道搜索好题
- 学习关于Bootstrap的感悟和体会
- pip常用操作
- React Native之AppRegistry模块
- Light OJ-----1045对数运算
- 自定义控件--头部视差
- 暑假小训练 (一道 不能不会的用结构体搜索题)
- Deep Convolutional Network Cascade for Facial Point Detection阅读笔记
- uva 1443 dp+二分
- C++封装、继承、多态(虚函数、虚指针、虚表)
- PHP学习笔记-文件操作1
- C++指针
- Python基础篇—Pandas应用(一)
- cocos2dx win平台集成使用protobuf
- iOS多线程编程(三)------ NSOperation