- hdu 3367 Pseudoforest 伪森林 题目很难懂,模仿kruskal,并查集检查两个节点是否是一个环
Lionel_D
并查集生成树图论Kruskal
PseudoforestTimeLimit:10000/5000MS(Java/Others)MemoryLimit:65536/65536K(Java/Others)TotalSubmission(s):2880AcceptedSubmission(s):1129ProblemDescriptionIngraphtheory,apseudoforestisanundirectedgraphinw
- 3367 Pseudoforest 伪森林 最小生成树
baolaoban
最小生成树最小生成树
这题做的我吐血,wang了n次了。刚开始题意理解错了,后来思路弄错。最后还是看了disscuss过得,引用下:【copy】这题题意理解了好一阵子才明白,给出一个图,要求出最大的pseudoforest,所谓pseudoforest就是指这个图的一个子图,这个子图的每个连通分量中最多只能有一个环,而且这个子图的所有权值之和最大。这个就是所谓的伪森林。过程类似与kruskal求最小生成树,千万不要直接
- Pseudoforest (并查集处理回路问题)
sdjzping
并查集
点击打开链接http://acm.hdu.edu.cn/showproblem.php?pid=33671、题目大意:求一个图的最大联通子图,要求每个联通分量最多只有一个环,且所求的边的权值之和最大,输入包括多组样例,每个样例第一行包含n/m两个整数,分别代表图中顶点的个数,边的个数。接下来的m行,每行有三个整数,分别表示一条边的起点和终点及权值,不存在圈不存在重复边,输入00结束每组样例输出一个
- 最大伪森林——kruskal算法活用 (HDU - 3367)
_int_me
最大伪森林——kruskal算法活用(HDU-3367)kruskal这一用来求生成树的算法,经过修改拓展之后,可以求很多种形式的子图,本题(HDU3367)即为一个应用案例单击进入原题以下是原题内容PseudoforestTimeLimit:10000/5000MS(Java/Others)MemoryLimit:65536/65536K(Java/Others)TotalSubmission(
- hdu3367 Pseudoforest(最大生成树+伪森林)
Flynn_curry
HDU
http://acm.hdu.edu.cn/showproblem.php?pid=3367题意:给你一个森林和一些边,求它的最大生成树。这个生成树里允许至多有一个环。思路:本题点数过多,不能用Prim。至于最大生成树,其实就是改变下排序顺序而已。关键是对伪森林的操作,允许至多有一个环。刚开始想的添加一个节点就判断是否可以构成环,然后能构成环的话把这个边存起来往复求最大值,最后找到最大值的边即为伪
- 专题四 第十二道题
qq_34273438
1.题目编号:10082.简单题意:给出一个图,要求出最大的pseudoforest,它是指这个图的一个子图,这个子图的每个连通分量中最多只能有一个环,而且这个子图的所有权值之和最大,就是伪森林3.解题思路形成过程:求最小生成树改成了求最大生成树4.感悟:并查集问题。。5.AC的代码:#include#include#includeusingnamespacestd;structnode{ in
- Problem H
qq_33720032
简单题意n个点,给你n条边,要求你连一些边,是边权总和最大(整个图可以不连通,对于每个连通子图最多只能有一个环)解题思路形成过程当初呢个题里面那个单词看不懂啊pseudoforest,去百度搜也没这个单词的意思,只有这个题啊,好吧我就看看别人写的题解吧,原来就是考虑环的问题。按照最大生成树的做法,只要在连接同一个连通子图的两个结点是判断该子图是否已有环,没有才可以连接。在连接不同连通子图的两个结点
- hdu-3367 Pseudoforest(伪森林, kruskal变形)
acm_cxq
ACMHDU
题目链接:点击打开链接PseudoforestTimeLimit:10000/5000MS(Java/Others) MemoryLimit:65536/65536K(Java/Others)TotalSubmission(s):2401 AcceptedSubmission(s):943ProblemDescriptionIngraphtheory,apseudoforestisan
- HDU 3367 Pseudoforest(Kruskal)
Dacc123
kruskalhdu3367
PseudoforestTimeLimit:10000/5000MS(Java/Others) MemoryLimit:65536/65536K(Java/Others)TotalSubmission(s):2382 AcceptedSubmission(s):933ProblemDescriptionIngraphtheory,apseudoforestisanundirectedg
- HDU 3367 Pseudoforest(最大生成树+并查集)
Grit_ICPC
并查集生成树
大意:n个点m条边,问如果每个联通分支中最多有一个环,最后可以组成的最大的权值和是多少。思路:类似一颗生成树,是的话那么一定是最大生成树。那么怎么判断是不是会有环的形成呢?那么就可以用并查集判断了,所以直接用克鲁斯卡尔算法算最大生成树即可。概括起来有两种情况:1、两个端点在同一集合,那么判断是不是有环(标记数组判定),2.不在同一集合,如果两边都有环也不可以。#include
#include
#
- hdu 3367 Pseudoforest(伪森林)
wqy20140101
ACM杭电并查集
ProblemDescriptionIngraphtheory,apseudoforestisanundirectedgraphinwhicheveryconnectedcomponenthasatmostonecycle.ThemaximalpseudoforestsofGarethepseudoforestsubgraphsofGthatarenotcontainedwithinanylarg
- hdoj--3367--Pseudoforest(伪森林&&最大生成树)
qq_29963431
PseudoforestTimeLimit:10000/5000MS(Java/Others) MemoryLimit:65536/65536K(Java/Others)TotalSubmission(s):2311 AcceptedSubmission(s):892ProblemDescriptionIngraphtheory,apseudoforestisanundirectedg
- hdu 3367 Pseudoforest
REST
http://acm.hdu.edu.cn/showproblem.php?pid=3367
1 #include <cstdio>
2 #include <cstring>
3 #include <algorithm>
4 #define maxn 20000
5 using namespace std;
6
7 int
- Hdu 3367 Pseudoforest
REST
Problem地址:http://acm.hdu.edu.cn/showproblem.php?pid=3367
如果懂一点并查集或Kruskal算法的话,这题并不算很难。题目求的是“伪森林”,也就是一颗或多颗”伪树“的集合(不知道是不是真有“伪树”这定义,我简单搜了一下,好像没有,这里的“伪树”就是指最多带一个环的树)。我刚开始用Kruskal直接生成一棵“最大生成树”,然后再
- HDU 3367 Pseudoforest
REST
题解:最大生成树加判环……
#include <cstdio>
#include <algorithm>
using namespace std;
struct node{int a,b,l;}seg[100005];
bool cmp(node a,node b){return a.l>b.l;}
int ans,m,n,f[10005],mark[10
- hdu3367Pseudoforest(最小生成树吧)
最小生成树
http://acm.hdu.edu.cn/showproblem.php?pid=3367
题意是让找出最大的森林 也就是符合它所要求的最大的边和 它要求每个连通块最多有一个圈就是一个环 可以用并查集判祖先
1 如果两个节点是一个祖先 就是一个连通块如果有圈 肯定不能合并 不然就两个圈了 就是这条边不要
2 不是一个祖先 如果是全都没圈直接合并 有一个有的合并加标记为此块有圈 Vie
- hdu 3367(Pseudoforest ) (最大生成树)
REST
Pseudoforest
Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Submission(s): 1844 Accepted Submission(s): 704 Prob
- hdu 3367 Pseudoforest(最大生成树)
REST
Pseudoforest
Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Total Submission(s): 1705 Accepted Submission(s): 653
Problem Desc
- hdu 3367 Pseudoforest(并查集)
REST
题意:求图的一最大联通子图,其中最多包含一个环。
思路:利用求最小生成树的方法(kruskal),排序时从大到小排序。连接时有三种情况:
1.一边有环,一边没有(可能两点已经在同一集合,也可能不在)
2.两边都没有环
3.两边都有环
如图:
思考了下 第一张图下边半部分画错了。。 可以是<的右边两个端点。
1 #include<iost
- hdu 3367 Pseudoforest
REST
Pseudoforest
Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Total Submission(s): 1070 Accepted Submission(s): 417 Pr
- hdu3367Pseudoforest (最大生成树之kruskal 算法)
REST
Problem Description In graph theory, a pseudoforest is an undirected graph in which every connected component has at most one cycle. The maximal pseudoforests of G are the pseudoforest subgraphs of
- hdu 3367 Pseudoforest
REST
每个连通分量最多只有一个环,求怎么连接使费用最大
按费用从大到小排序,一条一条加边,连接一个集合内两个点的时候,判断这个集合之前有没有成环,连接两个集合的时候,判断两个集合的状态,如果都没有,则合并后也没有环,如果有一个有环,合并有也有环,如果两个都有环,则不能合并。
#include<stdio.h>
#include<string.h>
#include<
- hdu 3367 伪森林(kruskal)
HDU
http://acm.hdu.edu.cn/showproblem.php?pid=3367
求pseudoforest伪森林,要求每个连通分量最多可以有一个环。求能构成的最大值
我是用kruskal的方法按照求最大生成树那样求的,只不过要加一个判断,就是判断两颗子树是够成环,如果各成环,就不能合并,如果只有其中一个成环或者都不成环,那么就可以合并,并对其进行标记。。。 View Cod
- HDU 3367 Pseudoforest (克鲁斯卡尔_最大生成树:带一环)
h1021456873
ProblemDescriptionIngraphtheory,apseudoforestisanundirectedgraphinwhicheveryconnectedcomponenthasatmostonecycle.ThemaximalpseudoforestsofGarethepseudoforestsubgraphsofGthatarenotcontainedwithinanylarg
- hdu3367Pseudoforest kruskal求最大生成树
cq_pf
最大生成树
//给一个图,问其边长之和最大伪森林
//伪森林是最终所有连通块最多有一个环
//刚开始的想法是在这个图的每一个连通子块找其最大生成树
//然后在这个子块中找一条不在这个树上加上去,这种想法是错误的,因为可能存在
//一个子块可能本来有两个环,但是删除一条小的边使得它成为两个子块比将这个子块删除一个环的边权和大
//正确的贪心策略是尽可能的找长的边,如果要合并的两颗子树中都有环就不合并,如果只有一
- HDU3367 Pseudoforest 【并查集】+【贪心】
u012846486
hdu3367
PseudoforestTimeLimit:10000/5000MS(Java/Others) MemoryLimit:65536/65536K(Java/Others)TotalSubmission(s):1729 AcceptedSubmission(s):661ProblemDescriptionIngraphtheory,apseudoforestisanundirectedg
- hdu3367 Pseudoforest
u011281853
题意是说求伪森林的边权之和最大。伪森林的定义是:每一个连通分量允许至多有一个环。这题本质上和kruskal差不多,但是要注意:因为要和最大,所以排序的时候从大到小。排序后枚举每一条边,判断它的两个端点:1.两个端点属于同一个集合。如果这个集合还没有环,那么就加上这条边并标记次集合有环2.两个端点属于不同的集合。如果这两个集合至多只有一个集合有环的话,那么就可以加上这条边合并这两个集合,一定记得要修
- HDU 3367 Pseudoforest 并查集求最大生成树及判断环
Dinivity123
点击打开链接PseudoforestTimeLimit:10000/5000MS(Java/Others) MemoryLimit:65536/65536K(Java/Others)TotalSubmission(s):1365 AcceptedSubmission(s):514ProblemDescriptionIngraphtheory,apseudoforestisanundir
- hdu 3367 Pseudoforest kruskal算法的变种+并查集
a601025382s
最小生成树
#include
#include
#include
#include
#include
#include
usingnamespacestd;
constintmaxn=10010;
constintmaxm=100010;
intf[maxn],vis[maxn];
structnode{
inta,b,w;
}e[maxm];
intfind(intx)
{
if(x!=f[x])f[x]=
- hdu3367Pseudoforest (最大生成树之kruskal 算法)
u010372095
kruskal最大生成树
ProblemDescriptionIngraphtheory,apseudoforestisanundirectedgraphinwhicheveryconnectedcomponenthasatmostonecycle.ThemaximalpseudoforestsofGarethepseudoforestsubgraphsofGthatarenotcontainedwithinanylarg
- scala的option和some
矮蛋蛋
编程scala
原文地址:
http://blog.sina.com.cn/s/blog_68af3f090100qkt8.html
对于学习 Scala 的 Java™ 开发人员来说,对象是一个比较自然、简单的入口点。在 本系列 前几期文章中,我介绍了 Scala 中一些面向对象的编程方法,这些方法实际上与 Java 编程的区别不是很大。我还向您展示了 Scala 如何重新应用传统的面向对象概念,找到其缺点
- NullPointerException
Cb123456
androidBaseAdapter
java.lang.NullPointerException: Attempt to invoke virtual method 'int android.view.View.getImportantForAccessibility()' on a null object reference
出现以上异常.然后就在baidu上
- PHP使用文件和目录
天子之骄
php文件和目录读取和写入php验证文件php锁定文件
PHP使用文件和目录
1.使用include()包含文件
(1):使用include()从一个被包含文档返回一个值
(2):在控制结构中使用include()
include_once()函数需要一个包含文件的路径,此外,第一次调用它的情况和include()一样,如果在脚本执行中再次对同一个文件调用,那么这个文件不会再次包含。
在php.ini文件中设置
- SQL SELECT DISTINCT 语句
何必如此
sql
SELECT DISTINCT 语句用于返回唯一不同的值。
SQL SELECT DISTINCT 语句
在表中,一个列可能会包含多个重复值,有时您也许希望仅仅列出不同(distinct)的值。
DISTINCT 关键词用于返回唯一不同的值。
SQL SELECT DISTINCT 语法
SELECT DISTINCT column_name,column_name
F
- java冒泡排序
3213213333332132
java冒泡排序
package com.algorithm;
/**
* @Description 冒泡
* @author FuJianyong
* 2015-1-22上午09:58:39
*/
public class MaoPao {
public static void main(String[] args) {
int[] mao = {17,50,26,18,9,10
- struts2.18 +json,struts2-json-plugin-2.1.8.1.jar配置及问题!
7454103
DAOspringAjaxjsonqq
struts2.18 出来有段时间了! (貌似是 稳定版)
闲时研究下下! 貌似 sruts2 搭配 json 做 ajax 很吃香!
实践了下下! 不当之处请绕过! 呵呵
网上一大堆 struts2+json 不过大多的json 插件 都是 jsonplugin.34.jar
strut
- struts2 数据标签说明
darkranger
jspbeanstrutsservletScheme
数据标签主要用于提供各种数据访问相关的功能,包括显示一个Action里的属性,以及生成国际化输出等功能
数据标签主要包括:
action :该标签用于在JSP页面中直接调用一个Action,通过指定executeResult参数,还可将该Action的处理结果包含到本页面来。
bean :该标签用于创建一个javabean实例。如果指定了id属性,则可以将创建的javabean实例放入Sta
- 链表.简单的链表节点构建
aijuans
编程技巧
/*编程环境WIN-TC*/ #include "stdio.h" #include "conio.h"
#define NODE(name, key_word, help) \ Node name[1]={{NULL, NULL, NULL, key_word, help}}
typedef struct node { &nbs
- tomcat下jndi的三种配置方式
avords
tomcat
jndi(Java Naming and Directory Interface,Java命名和目录接口)是一组在Java应用中访问命名和目录服务的API。命名服务将名称和对象联系起来,使得我们可以用名称
访问对象。目录服务是一种命名服务,在这种服务里,对象不但有名称,还有属性。
tomcat配置
- 关于敏捷的一些想法
houxinyou
敏捷
从网上看到这样一句话:“敏捷开发的最重要目标就是:满足用户多变的需求,说白了就是最大程度的让客户满意。”
感觉表达的不太清楚。
感觉容易被人误解的地方主要在“用户多变的需求”上。
第一种多变,实际上就是没有从根本上了解了用户的需求。用户的需求实际是稳定的,只是比较多,也比较混乱,用户一般只能了解自己的那一小部分,所以没有用户能清楚的表达出整体需求。而由于各种条件的,用户表达自己那一部分时也有
- 富养还是穷养,决定孩子的一生
bijian1013
教育人生
是什么决定孩子未来物质能否丰盛?为什么说寒门很难出贵子,三代才能出贵族?真的是父母必须有钱,才能大概率保证孩子未来富有吗?-----作者:@李雪爱与自由
事实并非由物质决定,而是由心灵决定。一朋友富有而且修养气质很好,兄弟姐妹也都如此。她的童年时代,物质上大家都很贫乏,但妈妈总是保持生活中的美感,时不时给孩子们带回一些美好小玩意,从来不对孩子传递生活艰辛、金钱来之不易、要懂得珍惜
- oracle 日期时间格式转化
征客丶
oracle
oracle 系统时间有 SYSDATE 与 SYSTIMESTAMP;
SYSDATE:不支持毫秒,取的是系统时间;
SYSTIMESTAMP:支持毫秒,日期,时间是给时区转换的,秒和毫秒是取的系统的。
日期转字符窜:
一、不取毫秒:
TO_CHAR(SYSDATE, 'YYYY-MM-DD HH24:MI:SS')
简要说明,
YYYY 年
MM 月
- 【Scala六】分析Spark源代码总结的Scala语法四
bit1129
scala
1. apply语法
FileShuffleBlockManager中定义的类ShuffleFileGroup,定义:
private class ShuffleFileGroup(val shuffleId: Int, val fileId: Int, val files: Array[File]) {
...
def apply(bucketId
- Erlang中有意思的bug
bookjovi
erlang
代码中常有一些很搞笑的bug,如下面的一行代码被调用两次(Erlang beam)
commit f667e4a47b07b07ed035073b94d699ff5fe0ba9b
Author: Jovi Zhang <
[email protected]>
Date: Fri Dec 2 16:19:22 2011 +0100
erts:
- 移位打印10进制数转16进制-2008-08-18
ljy325
java基础
/**
* Description 移位打印10进制的16进制形式
* Creation Date 15-08-2008 9:00
* @author 卢俊宇
* @version 1.0
*
*/
public class PrintHex {
// 备选字符
static final char di
- 读《研磨设计模式》-代码笔记-组合模式
bylijinnan
java设计模式
声明: 本文只为方便我个人查阅和理解,详细的分析以及源代码请移步 原作者的博客http://chjavach.iteye.com/
import java.util.ArrayList;
import java.util.List;
abstract class Component {
public abstract void printStruct(Str
- 利用cmd命令将.class文件打包成jar
chenyu19891124
cmdjar
cmd命令打jar是如下实现:
在运行里输入cmd,利用cmd命令进入到本地的工作盘符。(如我的是D盘下的文件有此路径 D:\workspace\prpall\WEB-INF\classes)
现在是想把D:\workspace\prpall\WEB-INF\classes路径下所有的文件打包成prpall.jar。然后继续如下操作:
cd D: 回车
cd workspace/prpal
- [原创]JWFD v0.96 工作流系统二次开发包 for Eclipse 简要说明
comsci
eclipse设计模式算法工作swing
JWFD v0.96 工作流系统二次开发包 for Eclipse 简要说明
&nb
- SecureCRT右键粘贴的设置
daizj
secureCRT右键粘贴
一般都习惯鼠标右键自动粘贴的功能,对于SecureCRT6.7.5 ,这个功能也已经是默认配置了。
老版本的SecureCRT其实也有这个功能,只是不是默认设置,很多人不知道罢了。
菜单:
Options->Global Options ...->Terminal
右边有个Mouse的选项块。
Copy on Select
Paste on Right/Middle
- Linux 软链接和硬链接
dongwei_6688
linux
1.Linux链接概念Linux链接分两种,一种被称为硬链接(Hard Link),另一种被称为符号链接(Symbolic Link)。默认情况下,ln命令产生硬链接。
【硬连接】硬连接指通过索引节点来进行连接。在Linux的文件系统中,保存在磁盘分区中的文件不管是什么类型都给它分配一个编号,称为索引节点号(Inode Index)。在Linux中,多个文件名指向同一索引节点是存在的。一般这种连
- DIV底部自适应
dcj3sjt126com
JavaScript
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml&q
- Centos6.5使用yum安装mysql——快速上手必备
dcj3sjt126com
mysql
第1步、yum安装mysql
[root@stonex ~]# yum -y install mysql-server
安装结果:
Installed:
mysql-server.x86_64 0:5.1.73-3.el6_5 &nb
- 如何调试JDK源码
frank1234
jdk
相信各位小伙伴们跟我一样,想通过JDK源码来学习Java,比如collections包,java.util.concurrent包。
可惜的是sun提供的jdk并不能查看运行中的局部变量,需要重新编译一下rt.jar。
下面是编译jdk的具体步骤:
1.把C:\java\jdk1.6.0_26\sr
- Maximal Rectangle
hcx2013
max
Given a 2D binary matrix filled with 0's and 1's, find the largest rectangle containing all ones and return its area.
public class Solution {
public int maximalRectangle(char[][] matrix)
- Spring MVC测试框架详解——服务端测试
jinnianshilongnian
spring mvc test
随着RESTful Web Service的流行,测试对外的Service是否满足期望也变的必要的。从Spring 3.2开始Spring了Spring Web测试框架,如果版本低于3.2,请使用spring-test-mvc项目(合并到spring3.2中了)。
Spring MVC测试框架提供了对服务器端和客户端(基于RestTemplate的客户端)提供了支持。
&nbs
- Linux64位操作系统(CentOS6.6)上如何编译hadoop2.4.0
liyong0802
hadoop
一、准备编译软件
1.在官网下载jdk1.7、maven3.2.1、ant1.9.4,解压设置好环境变量就可以用。
环境变量设置如下:
(1)执行vim /etc/profile
(2)在文件尾部加入:
export JAVA_HOME=/home/spark/jdk1.7
export MAVEN_HOME=/ho
- StatusBar 字体白色
pangyulei
status
[[UIApplication sharedApplication] setStatusBarStyle:UIStatusBarStyleLightContent];
/*you'll also need to set UIViewControllerBasedStatusBarAppearance to NO in the plist file if you use this method
- 如何分析Java虚拟机死锁
sesame
javathreadoracle虚拟机jdbc
英文资料:
Thread Dump and Concurrency Locks
Thread dumps are very useful for diagnosing synchronization related problems such as deadlocks on object monitors. Ctrl-\ on Solaris/Linux or Ctrl-B
- 位运算简介及实用技巧(一):基础篇
tw_wangzhengquan
位运算
http://www.matrix67.com/blog/archives/263
去年年底写的关于位运算的日志是这个Blog里少数大受欢迎的文章之一,很多人都希望我能不断完善那篇文章。后来我看到了不少其它的资料,学习到了更多关于位运算的知识,有了重新整理位运算技巧的想法。从今天起我就开始写这一系列位运算讲解文章,与其说是原来那篇文章的follow-up,不如说是一个r
- jsearch的索引文件结构
yangshangchuan
搜索引擎jsearch全文检索信息检索word分词
jsearch是一个高性能的全文检索工具包,基于倒排索引,基于java8,类似于lucene,但更轻量级。
jsearch的索引文件结构定义如下:
1、一个词的索引由=分割的三部分组成: 第一部分是词 第二部分是这个词在多少