noqqqqqqq 2023-12-24 00:20 采纳率: 0%
浏览 6

电路布线问题-分支限界方法。到底哪里错了啊


#include<iostream>
#include<queue>
using namespace std;
int m,n,ax,ay,bx,by;
int g[500][500];
int len;
struct node{
    int x;
    int y;
};
void wire(){  //分支限界,只要找到可行解必是最优解
    if(ax==bx && ay==by){
        len=0;
    }
    queue<node> q;
    node offset[4];
    offset[0].x=0; offset[0].y=1;  //right
    offset[1].x=1; offset[1].y=0;  //down
    offset[2].x=0; offset[2].y=-1;  //left
    offset[3].x=-1; offset[3].y=1;  //up
    int neighbour_num=4;
    node here,neighbour;
    here.x=ax; here.y=ay;
    g[ax][ay]=2;
    do{
        for(int i=0;i<neighbour_num;i++){
            neighbour.x=here.x+offset[i].x;
            neighbour.y=here.y+offset[i].y;
            if(g[neighbour.x][neighbour.y]==0){  //该方格未被标记
                g[neighbour.x][neighbour.y]=g[here.x][here.y]+1;
                if((neighbour.x == bx) && (neighbour.y == by)){
                    //布线完成
                    break;
                }
                q.push(neighbour);
            }
        }
        if((neighbour.x == bx) && (neighbour.y == by)){
            //布线完成
            break;
        }
        if(q.empty()){
            break;
        }
        here=q.front();
        q.pop();
    }while(1);
    return ;
}
int main(){
    cin>>m>>n;
    for(int i=0;i<=n;i++){
        g[0][i]=1;
        g[m+1][i]=1;
    }
    for(int i=0;i<=m;i++){
        g[i][0]=1;
        g[i][n+1]=1;
    }
    for(int i=1;i<=m;i++){
        for(int j=1;j<=n;j++){
            cin>>g[i][j];
        }
    }
    cin>>ax>>ay>>bx>>by;
    wire();
    if(len!=0){
        len=g[bx][by]-2;
    }
    cout<<len;
    return 0;
}
  • 写回答

2条回答 默认 最新

  • noqqqqqqq 2023-12-24 00:23
    关注

    有大佬可以帮帮我吗

    评论

报告相同问题?

问题事件

  • 创建了问题 12月24日

悬赏问题

  • ¥15 35114 SVAC视频验签的问题
  • ¥15 impedancepy
  • ¥15 在虚拟机环境下完成以下,要求截图!
  • ¥15 求往届大挑得奖作品(ppt…)
  • ¥15 如何在vue.config.js中读取到public文件夹下window.APP_CONFIG.API_BASE_URL的值
  • ¥50 浦育平台scratch图形化编程
  • ¥20 求这个的原理图 只要原理图
  • ¥15 vue2项目中,如何配置环境,可以在打完包之后修改请求的服务器地址
  • ¥20 微信的店铺小程序如何修改背景图
  • ¥15 UE5.1局部变量对蓝图不可见