当前位置: 首页 > news >正文

网软志成免费部队网站源码下载做跨境网站注意

网软志成免费部队网站源码下载,做跨境网站注意,wordpress 表情插件,胖子马wordpress模板:q8免费版资源限制 内存限制:256.0MB C/C时间限制:1.0s Java时间限制:3.0s Python时间限制:5.0s 问题描述 勇士们不小心进入了敌人的地雷阵(用n行n列的矩阵表示,*表示某个位置埋有地雷,-表示某个…

资源限制

内存限制:256.0MB   C/C++时间限制:1.0s   Java时间限制:3.0s   Python时间限制:5.0s

问题描述

  勇士们不小心进入了敌人的地雷阵(用n行n列的矩阵表示,'*'表示某个位置埋有地雷,'-'表示某个位置是安全的),他们各自需要在规定的步数(一步代表走到和当前位置相邻的位置)内绕开地雷到达出口(第一行第一格,即坐标为(0,0)的位置)才能完成任务,告诉你每个勇士的位置(x,y)和规定的步数s,请你判断每个勇士能否顺利完成任务(1代表“能”,-1代表“不能”)。

输入格式

  输入数据的第一行为一个整数n;第二行至第n+1行是n行n列地雷阵的矩阵表示(见输入样例);第n+2行至最后一行每行是一个勇士的位置x、y和到达出口规定的最大步数s,三个整数间用空格隔开。

输出格式

  按顺序输出对每个勇士是否能顺利完成任务的判断(1代表“能”,-1代表“不能”),对每个勇士的判断占一行。

样例输入

5
-----
--*--
-**--
-**--
*-*--
0 1 1
0 4 3
1 1 3
1 4 2
2 0 3
3 0 4
3 3 2
4 1 3

样例输出

1
-1
1
-1
1
1
-1
-1

数据规模和约定

  1≤n≤500,0≤x≤n-1,0≤y≤n-1,1≤s≤500

对每一个要求的判断的点都进行bfs,超时,仅供理解题意

#include<iostream>
#include<queue>
#include<string.h>
using namespace std;
const int N=505;
typedef struct point{int x;int y;int step;
}point;int dx[4]={0,1,0,-1},dy[4]={1,0,-1,0};int main(){int n;cin>>n;char map[N][N];for(int i=0;i<n;i++){for(int j=0;j<n;j++){cin>>map[i][j];}}int x,y,num;while(cin>>x>>y>>num){queue<point> q;bool st[N][N];memset(st,0,sizeof(st));point start;start.x=x;start.y=y;start.step=0;q.push(start);//bfswhile(q.size()){point p=q.front();if(p.x==0&&p.y==0){break;}for(int i=0;i<4;i++){int a=p.x+dx[i],b=p.y+dy[i];if(a>=0&&a<n&&b>=0&&b<n&&!st[a][b]&&map[a][b]=='-'){st[a][b]=true;point next;next.x=a,next.y=b,next.step=p.step+1;q.push(next);}}q.pop();}if(q.size()==0){cout<<"-1"<<endl;}else{if(q.front().step<=num){cout<<1<<endl;}else cout<<-1<<endl;}}return 0;
} 

bfs一次

#include<iostream>
#include<queue>
#include<string.h>
using namespace std;
const int N=505;
typedef struct point{int x;int y;int step;
}point;int dx[4]={0,1,0,-1},dy[4]={1,0,-1,0};
char map[N][N];
int dist[N][N];//(0,0)到点的距离,如果无法到达(x,y)点,dist为0 
bool st[N][N];
queue<point> q;
int n;void bfs(){while(q.size()){point p=q.front();for(int i=0;i<4;i++){int a=p.x+dx[i],b=p.y+dy[i];if(a>=0&&a<n&&b>=0&&b<n&&!st[a][b]&&map[a][b]=='-'){st[a][b]=true;point next;next.x=a,next.y=b,next.step=p.step+1;dist[a][b]=p.step+1;q.push(next);}}q.pop();}
}
int main(){cin>>n;for(int i=0;i<n;i++){for(int j=0;j<n;j++){cin>>map[i][j];}}point start;start.x=0,start.y=0,start.step=0;q.push(start);bfs();int x,y,num;while(cin>>x>>y>>num){//dist为0有两种情况,第一种是真的步数为0,第二种是到不了 if(x==0&&y==0) cout<<1<<endl;//第一种 else{if(dist[x][y]!=0&&dist[x][y]<=num){//在能到的前提下,步长小于等于num 可行 cout<<1<<endl; }else cout<<-1<<endl;}}return 0;
} 

思路:在判断之前,可以求出(0,0)到其他任何点的步数 ,存在dist数组中,然后对每一个点进行判断。

http://www.yayakq.cn/news/895459/

相关文章:

  • 汕头建站费用wordpress扫码提交数据库
  • 权威的赣州网站建设长沙设计网站建设
  • php做视频网站有哪些wordpress字体编辑插件下载
  • 杭州网站建设外包电商网站报价
  • 网站整体设计意图及其功能和镜像网站做友链
  • 教学网站开发应用方案温州市网站建设
  • 杭州网站建设响应式江苏建设厅执业网站
  • 清远建设网站网站如何实现多语言
  • 文章管理系统网站模板教育视频网站开发
  • 做直播网站需要证书吗河北明迈特的网站在哪里做的
  • 怎么看网站是asp还是php凉山州建设厅官方网站
  • 广告企业网站源码个人做医疗类网站违法
  • html5商城网站网络课程
  • 域名续费做网站电商网页建设
  • 马鞍山市 网站建设free wordpress themes 4 u
  • 电子商务网站建设目标分析企业网站优化方法
  • 网页设计一个网站网站备案幕布 下载
  • 三五互联做网站怎么样构建中小型企业网络
  • 南京图文制作中心关键词优化策略
  • 免费软件站做抽奖网站违法吗
  • 阳西住房和城乡规划建设局网站致力于邯郸网站建设制作服务_使众多客户将网站转化为网络市场营销.
  • 房屋设计装修网站甘肃兴城建设有限公司网站
  • 免费cms建站系统phpstudy建设网站教程
  • 中文网站建设和英文网站建设的区别外贸网站制作教程
  • 有专业做淘宝网站的美工吗网站和管理系统的区别
  • 什么企业适合做网站潍坊网站建设尚荣
  • 整站seo需要多少钱构建网站需要什么意思
  • 可以找人帮忙做设计的网站wordpress开启注册
  • 品牌网站大全手机网站被拦截怎么办怎么解决
  • 深圳正规网站制作哪里好网站申请qq