MZOJ 1345 hero
                                                            生活随笔
收集整理的這篇文章主要介紹了
                                MZOJ 1345 hero
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.                        
                                一道寬搜模版題,可寫錯(cuò)了兩個(gè)地方的我只得了56(掩面痛哭)
http://10.37.2.111/problem.php?id=1345
先看看正確的
#include <bits/stdc++.h> #define read read() #define up(i,l,r) for(int i = l; i<=r; i++) using namespace std;int read {int x = 0; char ch = getchar();while(ch < 48 || ch > 57) ch = getchar();while(ch >= 48 && ch <= 57) {x = 10 * x + ch - 48; ch = getchar();}return x; }const int N = 105;int n,m,k; int sx,sy,ex,ey; int ans = INT_MAX; int dx[] = {0,1,-1, 0,0};//上,下,左,右; int dy[] = {0,0, 0,-1,1}; struct node{int x,y,step;}st; int th[N][N],vis[N][N]; int nx,ny;void updata(int i,int p) {if(i==1) (nx += p) > n ?nx = n : nx; //上else if(i==2) (nx -= p) < 1 ?nx = 1 : nx;//下 else if(i==3) (ny -= p) < 1 ?ny = 1 : ny;//左 else if(i==4) (ny += p) > m ?ny = m : ny;//右 }void bfs() {queue<node>q;st.step = 0;st.x = sx;st.y = sy;q.push(st);vis[sx][sy]=1;while(!q.empty()){node cur = q.front(); q.pop();if(cur.x == ex && cur.y == ey) {printf("%d",cur.step); exit(0);}up(i,1,4){nx = cur.x + dx[i];ny = cur.y + dy[i]; if(nx < 1|| ny < 1 || nx > n || ny > m || vis[nx][ny]) continue;vis[nx][ny] = 1;node nxt; nxt.x = nx; nxt.y = ny; nxt.step = cur.step + 1;q.push(nxt);}}printf("Impossible"); }int main() {freopen("hero2.in","r",stdin);n = read; m = read; k = read;int x,y;int cnt = 0;up(i,1,k){x = read; y = read; th[x][y] = read;}sx = read; sy = read;ex = read; ey = read;bfs(); }錯(cuò)誤1:代碼筆誤;
void updata(int i,int p) {if(i==1) (nx += p) > n ?n : nx; //上else if(i==2) (nx -= p) < 1 ?1 : nx;//下 else if(i==3) (ny -= p) < 1 ?1 : ny;//左 else if(i==4) (ny += p) > m ?m : ny;//右 }看出什么了嗎? -> 忘了賦值了;
錯(cuò)誤2:思維漏洞;
?
if(th[nx][ny]) updata(i,th[nx][ny]);?
彈簧可以連續(xù)跳啊連續(xù)跳 -> 所以要多次更新
記住教訓(xùn)啊;
?
轉(zhuǎn)載于:https://www.cnblogs.com/mzg1805/p/10316175.html
總結(jié)
以上是生活随笔為你收集整理的MZOJ 1345 hero的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        - 上一篇: 高效管理论坛广告贴的小窍门
- 下一篇: linux 访问Windows 共享文件
