本题答案

棋盘

http://www.nowcoder.com/questionTerminal/ab4bfa47f67848b7bd47cff37121e3fb

include

include

include

using namespace std;
int map[105][105],val[105][105];
struct node{
int x,y,c,v;
};
queue<node>q;
int main() {
int m,n,di[4][2]={0,1,1,0,0,-1,-1,0},ans=0x7f7f7f7f;
memset(map,-1,sizeof(map));
memset(val,0x7f,sizeof(val));
cin>>m>>n;
for(int i=0;i<n;i++){
int x,y,c;
cin>>x>>y>>c;
map[x][y]=c;
}
q.push((node){1,1,map[1][1],0});
val[1][1]=0;
while(!q.empty()){
int x=q.front().x,y=q.front().y,c=q.front().c,v=q.front().v;
if(v>ans){
q.pop();
continue;
}
if(x==m&&y==m){
ans=min(ans,v);
q.pop();
continue;
}
for(int k=0;k<4;k++){
int dx=x+di[k][0],dy=y+di[k][1];
if(dx>0&&dy>0&&dx<=m&&dy<=m){
int bc=map[x][y],dc=map[dx][dy],mv=val[dx][dy],dv;
if(dc>=0&&bc>=0){
dv=v+(dc==bc?0:1);
if(mv>dv){
q.push((node){dx,dy,dc,dv});
val[dx][dy]=dv;
}
}else if(dc<0&&bc>=0){
if(mv>v+2){
q.push((node){dx,dy,bc,v+2});
val[dx][dy]=v+2;
}
}else if(dc>=0&&bc<0){
dv=v+(c==dc?0:1);
if(mv>dv){
q.push((node){dx,dy,dc,dv});
val[dx][dy]=dv;
}
}
}
}
q.pop();
}
if(ans==0x7f7f7f7f){
cout<<"-1"<<endl;
}else {
cout<<ans<<endl;
}
return 0;
}</node>

全部评论

相关推荐

评论
2
收藏
分享

创作者周榜

更多
正在热议
更多
# 春招至今,你的战绩如何? #
11367次浏览 96人参与
# 你的实习产出是真实的还是包装的? #
2013次浏览 42人参与
# 米连集团26产品管培生项目 #
6102次浏览 216人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
7684次浏览 43人参与
# 简历第一个项目做什么 #
31788次浏览 343人参与
# 重来一次,我还会选择这个专业吗 #
433634次浏览 3926人参与
# 巨人网络春招 #
11386次浏览 223人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
187253次浏览 1122人参与
# 牛客AI文生图 #
21456次浏览 238人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
152506次浏览 888人参与
# 研究所笔面经互助 #
118983次浏览 577人参与
# 简历中的项目经历要怎么写? #
310452次浏览 4223人参与
# AI时代,哪些岗位最容易被淘汰 #
63971次浏览 832人参与
# 面试紧张时你会有什么表现? #
30527次浏览 188人参与
# 你今年的平均薪资是多少? #
213187次浏览 1039人参与
# 你怎么看待AI面试 #
180244次浏览 1261人参与
# 高学历就一定能找到好工作吗? #
64345次浏览 620人参与
# 你最满意的offer薪资是哪家公司? #
76600次浏览 374人参与
# 我的求职精神状态 #
448210次浏览 3129人参与
# 正在春招的你,也参与了去年秋招吗? #
363606次浏览 2638人参与
# 腾讯音乐求职进展汇总 #
160707次浏览 1112人参与
# 校招笔试 #
471441次浏览 2964人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务