目录
奇怪的电梯
马的遍历
PERKET(个人认为很抽象)
奇怪的电梯
P1135 奇怪的电梯 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)
思路,还是用的bfs,建立一个结构体类型的队列,一个存当前的电梯层数,一个存当前走的步数
还要建一个bool类型的数组标记当前电梯层数是否走过
完整代码
#includeconst int N = 210; int n,a,b; int g[N]; int ans; bool vis[N]{}; struct node { int lou; int step; }; void bfs() { std::queue q; q.push({a,0}); while(!q.empty()) { node tmp=q.front(); q.pop(); int cur_low=tmp.lou,cur_step=tmp.step; if(cur_low==b) { std::cout< =1&&vis[cur_low-g[cur_low]]==false) { q.push({cur_low-g[cur_low],cur_step+1}); vis[cur_low-g[cur_low]]=true; } } std::cout<<-1; } int main() { std::cin >> n >> a >> b; for(int i = 1;i <= n;i ++) { std::cin >> g[i]; } bfs(); return 0; }
马的遍历
P1443 马的遍历 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)
思路:用bfs,八个坐标,依次遍历 ,没有搜索到的点就输出-1
超时代码:
#includeconst int N = 410; int n,m,x,y; int g[N][N]; bool vis[N][N]{}; int rr[10]={-1,-2,-2,-1,1,2,2,1}; int cc[10]={-2,-1,1,2,2,1,-1,-2}; struct node { int r,c,step; }; void bfs(int ii,int jj) { std::queue q; q.push({x,y,0}); memset(vis,false,sizeof(vis)); while(!q.empty()) { node tmp=q.front(); q.pop(); int cur_r=tmp.r,cur_c=tmp.c,cur_step=tmp.step; if(cur_r==ii&&cur_c==jj) { std::cout< =1&&next_r<=n&&next_c>=1&&next_c<=m&&vis[next_r][next_c]==false) { q.push({next_r,next_c,cur_step+1}); vis[next_r][next_c]=true; } } } std::cout<<-1<<" "; } int main() { std::cin >> n >> m >> x >> y; for(int i = 1;i <= n;i ++) { for(int j = 1;j <= m;j ++) { bfs(i,j); } std::cout<<"\n"; } return 0; }
因为每次都要进一次bfs,所以时间复杂度就提高了
所以只需要进一次bfs,用一个二维数组记录到达每个点的步数(因为要走下一个点必然会经过当前这个点)
ac代码
#includeconst int N = 410; int n,m,x,y; int g[N][N]; bool vis[N][N]{}; int rr[10]={-1,-2,-2,-1,1,2,2,1}; int cc[10]={-2,-1,1,2,2,1,-1,-2}; int ans[N][N]; struct node { int r,c,step; }; void bfs() { memset(ans,-1,sizeof(ans)); std::queue q; q.push({x,y,0}); memset(vis,false,sizeof(vis)); vis[x][y]=true; while(!q.empty()) { node tmp=q.front(); q.pop(); int cur_r=tmp.r,cur_c=tmp.c,cur_step=tmp.step; ans[cur_r][cur_c]=cur_step; for(int i = 0;i < 8;i ++) { int next_r=cur_r+rr[i]; int next_c=cur_c+cc[i]; if(next_r>=1&&next_r<=n&&next_c>=1&&next_c<=m&&vis[next_r][next_c]==false) { q.push({next_r,next_c,cur_step+1}); vis[next_r][next_c]=true; } } } } int main() { std::cin >> n >> m >> x >> y; bfs(); for(int i = 1;i <= n;i ++) { for(int j = 1;j <= m;j ++) { std::cout<
PERKET(个人认为很抽象)
P2036 [COCI 2008/2009 #2] PERKET - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)
思路:这道题用dfs,枚举选和不选两种状态,取最小值
完整代码
#includeconst int N = 15; int a[N],b[N]; int n,ans=999999999; void dfs(int i,int x,int y)//编号,酸度,甜度 { if(i>n) { if(x==1&&y==0) return; ans=std::min(std::abs(x-y),ans); return; } dfs(i+1,x*a[i],y+b[i]); dfs(i+1,x,y); } int main() { std::cin >> n; for(int i = 1;i <= n;i ++) { std::cin >> a[i] >> b[i]; } dfs(1,1,0); std::cout<
猜你喜欢
- 4天前(从“见世面”到“内在需要”:在海南,追问旅行的意义)从“见世面”到“内在需要”:在海南,追问旅行的意义
- 4天前(fender japan hybrid)Fender东京旗舰店盛大开幕在即,开售商品和店内服务提前揭晓
- 4天前(临沂 凯悦)临沂第一家凯悦嘉轩酒店开幕迎宾
- 4天前(岭南东方大酒店)粤西成势 | 阳江阳春长兴岭南东方酒店正式签约,粤西文旅再添明珠
- 4天前(大连aaaaa景区)辽宁大连A级旅游景区应急救护水平整体跃升
- 4天前(大黄山景区高质量发展联盟成立多少年)大黄山景区高质量发展联盟成立
- 4天前(殷建祥简历)全国十大牛商解码:殷建祥如何用178天技术突围打造星空梦星空房
- 4天前(“三天跨两城”催生租车新需求,神州租车清明跨城订单同比增长416%)“三天跨两城”催生租车新需求,神州租车清明跨城订单同比增长416%
- 4天前(携程租车加盟合作)携程租车加盟优势全解析:开启旅游出行市场新篇章
- 4天前(泸沽湖大酒店地址)泸沽湖岚岳酒店盛大开业|以摩梭文化为魂,打造高端度假新地标
网友评论
- 搜索
- 最新文章
- (2020广州车展哈弗)你的猛龙 独一无二 哈弗猛龙广州车展闪耀登场
- (哈弗新能源suv2019款)智能科技颠覆出行体验 哈弗重塑新能源越野SUV价值认知
- (2021款全新哈弗h5自动四驱报价)新哈弗H5再赴保障之旅,无惧冰雪护航哈弗全民电四驱挑战赛
- (海南航空现况怎样)用一场直播找到市场扩张新渠道,海南航空做对了什么?
- (visa jcb 日本)优惠面面俱到 JCB信用卡邀您畅玩日本冰雪季
- (第三届“堡里有年味·回村过大年”民俗花灯会活动)第三届“堡里有年味·回村过大年”民俗花灯会活动
- (展示非遗魅力 长安启源助力铜梁龙舞出征)展示非遗魅力 长安启源助力铜梁龙舞出征
- (阿斯塔纳航空公司)阿斯塔纳航空机队飞机数量增至50架
- (北京香港航班动态查询)香港快运航空北京大兴新航线今日首航
- (我在港航“呵护”飞机 每一次安全着陆就是最好的荣誉)我在港航“呵护”飞机 每一次安全着陆就是最好的荣誉
- 热门文章