假设我们有矩阵,其元素值非零即1
a11........a1m
...................
...................
an1........anm
定义aij与akl之间的距离为D(aij,akl)=abs(i-k)+abs(j-l)
标签:之间 个数 queue i++ 方向 class body scan col
3 4
0001
0011
0110
3 2 1 0
2 1 0 0
1 0 0 1
#include<bits/stdc++.h> #define N 1010 using namespace std; int n,m,px,py; char a[N][N]; int dp[N][N]; queue<int> qx,qy; int dx[4]={1,-1,0,0};//定义方向数组 int dy[4]={0,0,1,-1}; int main() { memset(dp,-1,sizeof(dp));//全部至-1 scanf("%d%d",&n,&m); for(int i=1;i<=n;i++){ for(int j=1;j<=m;j++){ cin>>a[i][j]; if(a[i][j]==‘1‘) qx.push(i),qy.push(j),dp[i][j]=0;//如果输入值为1,答案置零,推入队列 } } while(!qx.empty()&&!qy.empty()){//如果队列不为空 px=qx.front();qx.pop(); py=qy.front();qy.pop(); for(int i=0;i<4;i++){//四个方向开始搜索 int nx=px+dx[i],ny=py+dy[i]; if(nx>=1&&nx<=n&&ny>=1&&ny<=m){ if(dp[nx][ny]==-1){//如果没有被访问过 dp[nx][ny]=dp[px][py]+1;//更新答案 qx.push(nx); qy.push(ny); } } } } for(int i=1;i<=n;i++){ for(int j=1;j<=m;j++){ printf("%d ",dp[i][j]); } printf("\n"); } return 0; }
标签:之间 个数 queue i++ 方向 class body scan col
原文地址:https://www.cnblogs.com/earth833/p/11282054.html