Hopcroft-Karp算法模板

2024-06-16 16:38
文章标签 算法 模板 karp hopcroft

本文主要是介绍Hopcroft-Karp算法模板,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

http://blog.csdn.net/u011742541/article/details/14104573


//Hopcroft-Karp算法 有点类似dinic 都是先对图BFS分层再沿层数DFS找增广路    
//***************************************************************************    
bool searchPath()        //BFS 对二分图分层    
{  dist = inf;  queue<int>que;  memset( dx,-1,sizeof(dx) );  memset( dy,-1,sizeof(dy) );  for( int i = 1; i <= nx; i ++ ){  //找到x集合所有未被匹配的点压入队列中  if( cx[i] == -1 ){  que.push(i);  dx[i] = 0;  }  }  while( !que.empty() ){  int u = que.front(); que.pop();  if( dx[u] > dist )    //只分层到第一个找个的可匹配点层数  break;  for( int v = 1; v <= ny; v ++ ) {  if( map[u][v] && dy[v] == -1 ){  dy[v] = dx[u] + 1;  if( cy[v] == -1 )      //找个一个可以匹配点 标记分层的层数   dist = dy[v];  else{  dx[cy[v]] = dy[v] + 1;  que.push( cy[v] );  }  }  }  }  return dist != inf;          
}  
bool findPath( int u )    //沿着层数DFS    
{  for( int v = 1; v <= ny; v ++ ){  if( map[u][v] && !vis[v] && dy[v] == dx[u] + 1 ){  vis[v] = true;  if( cy[v] != -1 && dy[v] == dist  )    //如果v已经有匹配了且v的层数为dist( 最大层数为dist 所以v原来匹配的不可能再匹配 )  continue;  if( cy[v] == -1 || findPath( cy[v] ) ){   //如果v未匹配就跟u匹配v 否则看v原来匹配的是否还能跟其他的匹配 能就跟u匹配 不能就不匹配   cy[v] = u;  cx[u] = v;  return true;  }  }  }  return false;  
}  
int HK_MaxMatch()  
{  int ans = 0;  memset( cx,-1,sizeof(cx) );  memset( cy,-1,sizeof(cy) );  while( searchPath() ){   //分层 + 判断是否还有未匹配点  memset( vis,0,sizeof(vis) );  for( int i = 1; i <= nx; i ++ ){    if( cx[i] == -1 )  ans += findPath(i);  }  }  return ans;  
}  
//***************************************************************************   


这篇关于Hopcroft-Karp算法模板的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1066973

相关文章

Java如何根据word模板导出数据

《Java如何根据word模板导出数据》这篇文章主要为大家详细介绍了Java如何实现根据word模板导出数据,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... pom.XML文件导入依赖 <dependency> <groupId>cn.afterturn</groupId>

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Springboot实现推荐系统的协同过滤算法

《Springboot实现推荐系统的协同过滤算法》协同过滤算法是一种在推荐系统中广泛使用的算法,用于预测用户对物品(如商品、电影、音乐等)的偏好,从而实现个性化推荐,下面给大家介绍Springboot... 目录前言基本原理 算法分类 计算方法应用场景 代码实现 前言协同过滤算法(Collaborativ

Python中Flask模板的使用与高级技巧详解

《Python中Flask模板的使用与高级技巧详解》在Web开发中,直接将HTML代码写在Python文件中会导致诸多问题,Flask内置了Jinja2模板引擎,完美解决了这些问题,下面我们就来看看F... 目录一、模板渲染基础1.1 为什么需要模板引擎1.2 第一个模板渲染示例1.3 模板渲染原理二、模板

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财

如何在 Spring Boot 中实现 FreeMarker 模板

《如何在SpringBoot中实现FreeMarker模板》FreeMarker是一种功能强大、轻量级的模板引擎,用于在Java应用中生成动态文本输出(如HTML、XML、邮件内容等),本文... 目录什么是 FreeMarker 模板?在 Spring Boot 中实现 FreeMarker 模板1. 环

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.