这题不难,求哈密顿路的,就是多了一个限制条件。
主要是合并满足给定路径的哈密顿路时要进行合并,可以用并查集的来做,我是直接用哈希表来做的,求出满足条件一共有几组的聚集后,其实就是求这些聚集的一个全排列,只不过聚集本身有可以变换为两种情况,不管怎样,这在高中排列组合中学过,还是很简单的。
另外,由于Java中提供了大数,因此可以用大数做比较大的那种运算,如求50的全排列。
~~.
import java.util.*;
import java.util.regex.*;
import java.math.*;
public class HamiltonPath {
public int countPaths(String[] roads) {
int ans=0;
int n=roads.length;
char[][] matrix=new char[n][n];
Vector<HashSet<String>> vec=new Vector<HashSet<String>>();
for(int i=0;i<n;i++){
matrix[i]=roads[i].toCharArray();
}
for(int i=0;i<n;i++){
int iflag=0;
for(int j=0;j<n;j++){
if(matrix[i][j]=='Y')
iflag++;
}
if(iflag>2)
return 0;
}
for(int i=0;i<n;i++){
for(int j=i+1;j<n;j++){
if(matrix[i][j]=='Y'){
Vector<HashSet<String>> ll=new Vector<HashSet<String>>();
boolean isIn=false;
for(HashSet<String> hs:vec){//loop 1
if(hs.contains(i+"")){
if(hs.contains(j+""))
return 0;
else{
ll.add(hs);
hs.add(j+"");
isIn=true;
}
}else if(hs.contains(j+"")){
if(hs.contains(i+""))
return 0;
else{
ll.add(hs);
hs.add(i+"");
isIn=true;
}
}
}//loop 1 over
merge(ll,vec);
if(!isIn){
HashSet<String> hs=new HashSet<String>();
hs.add(i+"");
hs.add(j+"");
vec.add(hs);
}
}//if
}//inner for loop
}//outter for loop
int temp=0;
for(HashSet<String> hs:vec){
temp+=hs.size();
}
int n1=n-temp;
int n2=vec.size();
BigInteger big=getAllPos(n1+n2);
long pow=get2Pow(n2);
big=big.multiply(new BigInteger(pow+""));
ans=big.mod(new BigInteger(""+1000000007)).intValue();
return ans;
}
BigInteger getAllPos(int n){
BigInteger ans=BigInteger.ONE;
for(int i=1;i<=n;i++)
ans=ans.multiply(new BigInteger(i+""));
return ans;
}
void merge(Vector<HashSet<String>> ll,Vector<HashSet<String>> vec){
if(ll.size()>1){
HashSet<String> init=ll.get(0);
for(int i=1;i<ll.size();i++){
Iterator<String> itor=ll.get(i).iterator();
while(itor.hasNext())
init.add(itor.next());
}
for(int i=1;i<ll.size();i++){
vec.remove(ll.get(i));
}
}
}
long get2Pow(int n){
long ans=1;
while(n-->0){
ans*=2;
}
return ans;
}
}
分享到:
相关推荐
topcoder的数学类算法题目。一个整数被称为k-smooth当且仅当它的最大素因子不大于k,给定N和K,计算出1 - N中有多少个整数是k-smooth。1 , 1 <= K <= 1000.
SRM2Multi dumper for hsap
2. **SRM服务器**:运行SRM软件的物理或虚拟服务器,操作系统需为Server 2008 x64。 3. **支持SRM的数据库**:这里指能够被SRM兼容的数据库系统,例如SQL Server 2005。该数据库用于存储SRM的相关配置信息。 4. **...
SAP SRM 介绍
Driver HASP SRM emulator (x86)
根据给定的文件信息,我们将深入探讨“SRM-MDM Catalog Setup – Ready Reference”这一主题,专注于SAP NetWeaver MDM系统中的SRM-MDM目录设置过程。这份文档不仅适用于SAP SRM(Supplier Relationship Management...
2. OMRON产品命名约定:OMRON公司产品的型号在本手册中都是以大写形式出现,包括“CPM1”,“CPM1A”,“CPM2A”,“CPM2C”,“SRM1(-V2)”等。这可能是为了方便阅读时对产品型号的快速识别。此外,手册中提到的...
2. **边界长度**:`srm_boundarylen.cpp`可能是用于计算相邻区域边界的长度,这是评估区域合并代价的另一个因素。较长的边界通常意味着更高的合并成本,因为这会引入更多的不确定性。 3. **SRM主程序**:`srm.m`是...
版本: 1.0.0 作者: Semen Zhydenko ... BridgeCrossingOptimized.java - SRM 146 DIV 2,1000 点问题,时间复杂度 O(n^(n^2))。 BridgeCrossingBest.java - SRM 146 DIV 2,1000 点问题,时间复杂度 O(n)。
【标题】"VSAN与SRM"涉及到的是VMware虚拟化环境中的两个关键组件:Virtual SAN(VSAN)和Site Recovery Manager(SRM)。这两个工具在企业级数据中心中发挥着至关重要的作用,确保业务连续性和灾难恢复能力。 VSAN...
HASP SRM加密狗简介 HASP SRM加密狗是一种软件保护解决方案,由阿拉丁公司开发。它提供了多种型号,以满足不同业务需要。下面将对HASP SRM加密狗的各种型号进行详细介绍。 首先是HASP HL基本型,这是阿拉丁公司最...
2. 扩展、加强与重要供应商的关系:SRM 能够帮助企业与其建立合作关系,共享计划、产品设计和规范信息,并运作方式上进行改进。 3. 建立竞争优势:SRM 能够主动地帮助企业去建立、改进与供应商之间的战略同盟,不是...
**SRM系统资源管理器详解** SRM(System Resource Manager)系统资源管理器是一个专为Linux环境设计的工具,它的主要功能是作为一个守护进程在后台持续监控非root用户的进程,以便控制系统的CPU和内存(MEM)资源...
【标题】"SRM 210 供应商关系管理"涉及的是SAP的企业级采购解决方案,SAP Supplier Relationship Management(SRM)系统的一个特定版本。SRM 210是这个模块的一个迭代,旨在帮助企业更有效地管理和优化其与供应商的...
多年SRM实施经验总结,对希望从事SRM实施或规划的同学们有帮助
2. **合同管理**:制定明确的合同条款,确保双方权益,同时设定性能指标和违约处理机制。 3. **供应链协同**:通过信息共享,提高供应链的透明度,实现供需同步,减少库存和响应时间。 4. **供应商绩效评估**:...
分块描述SRM系统的作用:寻源、协同和考核 涉及具体的业务用途,供前期规划作参考,可根据实际情况调整,再考虑如何实现
**2. 任务概述** 2.1 现状与目标:当前,企业在供应商管理上存在信息不统一、流程复杂等问题。目标是通过SRM系统实现采购流程自动化,提高数据准确性和决策效率。 2.2 项目运行环境:系统需适应企业现有的IT基础设施...
2. **从客户端SRM系统加载参考数据** 3. **在SRM中设置外部Web服务** 4. **在组织计划中使目录Web服务可用** 5. **配置WebDynpro中的搜索UI** ##### 1. 准备主数据客户端(SRM)系统 - **激活MDM-SRM接口**:确保...