poj 3026 Borg Maze (最小生成树+bfs)

  有几个错误,调试了几个小时,样例过后 1Y.

题目:http://poj.org/problem?id=3026

题意:就是让求A们和S的最小生成树

先用bfs找每两点的距离,再建树。没剪枝 63MS。

  1 #include <iostream>
  2  #include<cstdio>
  3  #include<cstring>
  4  #include<cstdlib>
  5  #include<stack>
  6  #include<queue>
  7  #include<cmath>
  8  #include<algorithm>
  9  using namespace std;
 10  
 11  char G[60][60];
 12  int dx[5]={0,0,1,-1};
 13  int dy[5]={1,-1,0,0};
 14  int r,c,bin[10010],an,ff[150][150]; //an表示边数
 15  struct node
 16  {
 17      int x,y;
 18  }e[150];   //表示点
 19  
 20  struct tree
 21  {
 22      int u,v,w;
 23  }q[11000];//边及权值
 24  
 25  struct point
 26  {
 27      int x,y,step;
 28  }next,pos;//bfs 里的队列
 29  
 30  void add(int u,int v,int w)//加边
 31  {
 32       q[an].u=u; q[an].v=v; q[an++].w=w;
 33  }
 34  
 35  void bfs(int f,int x,int y)
 36  {
 37      int vis[60][60],i;
 38       queue<point>qu;
 39      memset(vis,0,sizeof(vis));
 40      next.x=x; next.y=y; next.step=0;
 41      qu.push(next);
 42      vis[x][y]=1;
 43      while(!qu.empty())
 44      {
 45          pos=qu.front();
 46          qu.pop();
 47          for(i=0; i<4; i++)
 48          {
 49              next.x=pos.x+dx[i]; next.y=pos.y+dy[i]; next.step=pos.step+1;
 50              if(next.x>=0 && next.x<r && next.y>=0 && next.y<c && vis[next.x][next.y]==0 && G[next.x][next.y]!='#')
 51              {
 52                  vis[next.x][next.y]=1;
 53                  qu.push(next);
 54                  if(G[next.x][next.y]=='A'||G[next.x][next.y]=='S')
 55                    add(f,ff[next.x][next.y],next.step);
 56              }
 57          }
 58      }
 59  }
 60  int cmp(const void *a,const void *b)
 61  {
 62      return (*(tree *)a).w-(*(tree *)b).w;
 63  }
 64  int find(int a)
 65  {
 66     if(a==bin[a])
 67     return a;
 68     else
 69     bin[a]=find(bin[a]);
 70  };
 71  int main()
 72  {
 73      int t,cnt,i,j,x,y,num,sum;//cnt表示点的个数
 74      char str[200];
 75      cin>>t;
 76      while(t--)
 77      {
 78          sum=0; num=0; an=0;
 79          cin>>c>>r;
 80          gets(str);
 81          for(i=0; i<r; i++)
 82          gets(G[i]);
 83  
 84          cnt=0;
 85          for(i=0; i<r; i++)
 86          for(j=0; j<c; j++)
 87          if(G[i][j]=='S'||G[i][j]=='A')
 88          {
 89            ff[i][j]=cnt;
 90            e[cnt].x=i; e[cnt++].y=j;
 91          }
 92  
 93          for(i=0; i<cnt; i++)
 94          {
 95              bfs(i,e[i].x,e[i].y);
 96          }
 97  
 98          for(i=0; i<cnt; i++)
 99          bin[i]=i;
100          qsort(q,an,sizeof(q[0]),cmp);
101          for(i=0; i<=an-1; i++)
102          {
103              x=find(q[i].u); y=find(q[i].v);
104              if(x!=y)
105              {
106                  sum+=q[i].w;
107                  num++;
108                  bin[x]=y;
109              }
110              if(num==cnt-1)
111              break;
112          }
113          printf("%d\n",sum);
114      }
115  }
116  

 

 

转载于:https://www.cnblogs.com/bfshm/p/3253262.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/575809.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

webview 调用java_Android中在WebView里实现Javascript调用Java类的方法

为了方便网页和Android应用的交互&#xff0c;Android系统提供了WebView中JavaScript网页脚本调用Java类方法的机制。只要调用addJavascriptInterface方法即可映射一个Java对象到JavaScript对象上。1、映射Java对象到JavaScript对象上mWebView (WebView) findViewById(R.id.wv…

VS的一部分快捷键

快捷键 功能CTRL SHIFT B 生成解决方案CTRL F7 生成编译CTRL O 打开文件CTRL SHIFT O 打开项目…

java 合并流_Java Stream 流实现合并操作示例

本文实例讲述了Java Stream 流实现合并操作。分享给大家供大家参考&#xff0c;具体如下&#xff1a;1. 前言Java Stream Api提供了很多有用的 Api 让我们很方便将集合或者多个同类型的元素转换为流进行操作。今天我们来看看如何合并 Stream 流。2. Stream 流的合并Stream 流合…

java 去掉 t_java中的“\t”

对于初学者来说&#xff0c;java中的"\t"和空格总是让人迷惑&#xff0c;其实很简单&#xff0c;通过一个例子就能很快明白&#xff01;比如说打印九九乘法表&#xff01;先来看用空格的效果&#xff01;1 package cn.edu.nwpu.java;23 public class MultiplicationT…

如何检测文件中的违禁词和小于规定大小的文件?

1 <?php2 foreach(array(a.txt,b.txt,c.txt) as $v){3 4 $file./article/.$v;5 6 if(filesize($file)<10){7 8 echo $v."文件小于10字节&#xff0c;已经被删除"."<br/>";9 unlink($file); 10 continue;} 11 $confile_get_contents(…

java excel 操作方式_Java读写Excel基本操作

Apache POI是Apache软件基金会的开放源码函式库&#xff0c;POI提供API给Java程式对Microsoft Office格式档案读和写的功能。接口&#xff1a;HSSF &#xff0d; Microsoft ExcelXSSF &#xff0d; Microsoft Excel OOXML(07以上版本)HWPF &#xff0d; Microsoft WordHSLF &am…

C语言根据日期(年,月,日)判断星期几(使用基姆拉尔森计算公式)

C语言根据日期判断星期几&#xff08;使用基姆拉尔森计算公式&#xff09; 算法如下&#xff1a; 基姆拉尔森计算公式W (d2*m3*(m1)/5yy/4-y/100y/400) mod 7 在公式中d表示日期中的日数&#xff0c;m表示月份数&#xff0c;y表示年数。 注意&#xff1a;在公式中有个与其他公式…

java service层 事务_Java高并发秒时啊API之Service层1

---2-1 使用Spring托管Service依赖理论----------------------------spring ioc优势(工厂模式):1.对象创建统一托管2.规范的生命周期管理3.灵活的依赖注入4.一致的获取对象Spring IOC 功能的理解DAO依赖Service依赖最终形成一致访问接口&#xff1b;随意访问依赖对象Spring IOC…

【网摘阅读】舒迅:产品经理必读的九步法

前几天读到一篇文章&#xff0c;觉得内容很好&#xff0c;推荐一下。本文摘自 http://www.huangshaofeng.com/422 产品设计“九步法” 第一步&#xff1a;产品满足用户的哪一个核心需求&#xff1f; 第二步&#xff1a;与同类产品相比你的独特性什么&#xff1f; 第三步&…

zoj 3720

为什么注释掉的地方是错的&#xff1f; 自己的代码好糟烂..... 直接枚举点 判是否在多边形内 加起来求概率 求面积的时候代码写搓了.... 比不过别人两行的代码 而且到现在还找不到错..... #include <iostream> #include <fstream> #include <cstri…

void在java中是什么意思_java中void什么意思

在java中&#xff0c;void代表的意思是“空”&#xff0c;即“什么都不返回”&#xff0c;在方法申明的时候表示该方法没有返回值。void对应着一个Void类&#xff0c;Void类是用final修饰的&#xff0c;是一个不可实例化的占位符类。之前&#xff0c;在学C的数据类型的时候发现…

《设计模式》-模板模式

玩物丧志啊&#xff01;&#xff01;&#xff01;最近总想着玩&#xff0c;休息&#xff0c;结果又耽误了半个月。。唉&#xff01; 惭愧啊。 今天是设计模式的倒数第二个了。。 虽然前面的 忘得差不多了。不过等看完了 要进行总复习&#xff0c;再复习&#xff0c;再回归&…

java 多个方法_java中的多个main()方法

它不会导致错误.只是因为你初始化一个对象,并不意味着main方法被执行. Java只会最初调用传递给它的类的main方法> java TestClass但是,做一些事情&#xff1a;public class TestClass{public static void main (String[] args){TestClass foo new TestClass();foo.main(arg…

一看就会之—利用IIS服务发布网站(实践篇)上

转自&#xff1a;http://blog.csdn.net/zwk626542417/article/details/9796259 概述 IIS全称为互联网信息服务&#xff0c;是由微软公司提供的基于运行MicrosoftWindows的互联网基本服务&#xff0c;今天我们主要来看下如何用win7系统自带的IIS服务来发布我们开发的一个简单的…

java md5 算法实现_Java 实现Md5算法

package other;import java.security.MessageDigest;import java.security.NoSuchAlgorithmException;/** MD5 算法*/public class MD5 {// 全局数组private final static String[] strDigits { "0", "1", "2", "3", "4", …

xp变量 java_winxp系统设置java环境变量的详细教程

我们都知道想要进行java的程序编辑&#xff0c;就要首先在电脑上设置环境变量&#xff0c;这样才能够运行java程序&#xff0c;下面一起看看xp系统的电脑如何设置java变量。1、设置环境变量之前&#xff0c;我们肯定首先需要安装java&#xff0c;首先&#xff0c;找到你安装jav…

Context 之我见

Context这个单词在程序开发中屡见不鲜&#xff0c;我记得以前在博客中写过一些关于这个词语的自我解释&#xff0c;但是我这个人有一个毛病就是健忘&#xff0c;如果不将自己的想法写下&#xff0c;不出十分钟&#xff0c;就被我抛到九霄云外。 真我现在还有点想法&#xff0c;…

java按钮随机移动_java – 使按钮移动触摸我们触摸的确切位置

我创建了一个应用程序,其中有一个按钮在触摸它时移动.现在对于onTouch,我实现了一个不同的类.有两个类,一个是主要的CircleMActivity.java,另一个是onTouch.现在应用程序运行正常,但有一个问题.当我点击按钮并移动它时它正在移动,但按钮和屏幕触摸之间有一个间隙.我想要的是将它…

MySQL性能优化的最佳经验

今天&#xff0c;数据库的操作越来越成为整个应用的性能瓶颈了&#xff0c;这点对于Web应用尤其明显。关于数据库的性能&#xff0c;这并不只是DBA才需要担心的事&#xff0c;而这更是我们程序员需要去关注的事情。当我们去设计数据库表结构&#xff0c;对操作数据库时&#xf…

jspstudy mysql_使用JspStudy集成环境快速部署jsp项目

标签&#xff1a;1. 安装jdk本人网盘资源&#xff1a;https://yunpan.cn/ckZLNbqxkDYYe (提取码&#xff1a;b5e8)去jdk官网下载最新的jdk: http://www.oracle.com/technetwork/java/javase/downloads/jdk-7u2-download-1377129.html2. 配置环境变量&#xff1a;1) 系统变量→新…