pku2516 Minimum Cost

模板题

首先先明白一个概念,二分图的最大权匹配就是二分图的相等子图的完备匹配。因此在构图的时候并不需要“补点”。但要注意的是,我们要求的实质上是点集X的匹配,因此构图必须满足|X|<=|Y|。如果你坚持一定要补点才能KM的话,请说说你的理由,我们来讨论一下,这样才有进步

#include  < iostream >
using   namespace  std;

#define  MAXN 151
#define  INF 0x7f7f7f7f

int  shopkeeper[MAXN][MAXN],supply[MAXN][MAXN],cost[MAXN][MAXN][MAXN],N,M,K,nx,ny,map[MAXN][MAXN],sx[MAXN],sy[MAXN],ym[MAXN],xm[MAXN],lx[MAXN],ly[MAXN];
int  sum1,sum2;

int  DFS( int  u){
    sx[u]
= 1 ;
    
int  v;
    
for (v = 1 ;v <= ny;v ++ ){
        
if (lx[u] + ly[v] == map[u][v]  &&   ! sy[v]){
            sy[v]
= 1 ;
            
if (ym[v] ==- 1   ||  DFS(ym[v])){
                ym[v]
= u;
                xm[u]
= v;
                
return   1 ;
            }
        }
    }
    
return   0 ;
}

void  KM(){ // 求最大权的KM;若要求最小值,则把图的权设为负,输出也设为负。注意建图时需满足ny>=nx
     int  i,j,k;
    
// 初始化顶标
    memset(ly, 0 , sizeof (ly));
    
for (i = 1 ;i <= nx;i ++ ){
        lx[i]
=- INF;
        
for (j = 1 ;j <= ny;j ++ )
            
if (map[i][j] > lx[i]) // (1)
                lx[i] = map[i][j];
    }
    memset(ym,
- 1 , sizeof (ym));
    
for (i = 1 ;i <= nx;i ++ ){
        
while ( 1 ){
            memset(sx,
0 , sizeof (sx));
            memset(sy,
0 , sizeof (sy));
            
if (DFS(i)) // 要做到完备匹配,需要找到nx次增广路
                 break ;
            
// 修改顶标过程
             int  d = INF;
            
for (j = 1 ;j <= nx;j ++ ){
                
if (sx[j]){
                    
for (k = 1 ;k <= ny;k ++ ){
                        
if ( ! sy[k]  &&  d > lx[j] + ly[k] - map[j][k]){ // 根据最后一次不成功的寻找交错路的DFS,取所有i被访问到而j没被访问到的边(i,j)的lx[i]+ly[j]-w[i][j]的最小值d
                            d = lx[j] + ly[k] - map[j][k];
                        }
                    }
                }
            }
            
for (j = 1 ;j <= nx;j ++ )
                
if (sx[j])
                    lx[j]
-= d;
            
for (j = 1 ;j <= ny;j ++ )
                
if (sy[j])
                    ly[j]
+= d;
            
/*
            若求的是最大权:
            注意到由(1)可知初始化后的顶标必定满足lx[i]+ly[j]>=map[i][j]
            两端都在交错树中的边(i,j),lx[i]+ly[j]的值没有变化。也就是说,它原来属于相等子图,现在仍属于相等子图。 
            两端都不在交错树中的边(i,j),lx[i]和ly[j]都没有变化。也就是说,它原来属于(或不属于)相等子图,现在仍属于(或不属于)相等子图。 
            i端不在交错树中,j端在交错树中的边(i,j),它的lx[i]+ly[j]的值有所增大。它原来不属于相等子图,现在仍不属于相等子图。 
            i端在交错树中,j端不在交错树中的边(i,j),它的lx[i]+ly[j]的值有所减小。也就说,它原来不属于相等子图,现在可能进入了相等子图,因而使相等子图得到了扩大。
            
*/
        }
    }
}

int  main(){
    
int  i,j,k,l1,l2,ii,jj,ans,res;
    
bool  flag;
    
while (scanf( " %d%d%d " , & N, & M, & K)  &&  N + M + K){
        
// input
         for (i = 1 ;i <= N;i ++ ){
            
for (j = 1 ;j <= K;j ++ ){
                scanf(
" %d " , & shopkeeper[i][j]);
            }
        }
        
for (i = 1 ;i <= M;i ++ ){
            
for (j = 1 ;j <= K;j ++ ){
                scanf(
" %d " , & supply[i][j]);
            }
        }
        
for (k = 1 ;k <= K;k ++ ){
            
for (i = 1 ;i <= N;i ++ ){
                
for (j = 1 ;j <= M;j ++ ){
                    scanf(
" %d " , & cost[k][i][j]);
                }
            }
        }
        
// 判断是否供不应求
        flag = true ;
        
for (k = 1 ;k <= &&  flag;k ++ ){
            sum1
= sum2 = 0 ;
            
for (i = 1 ;i <= N;i ++ )
                sum1
+= shopkeeper[i][k];
            
for (i = 1 ;i <= M;i ++ )
                sum2
+= supply[i][k];
            
if (sum1 > sum2)
                flag
= false ;
        }
        
if ( ! flag){
            printf(
" -1\n " );
            
continue ;
        }

        
// 建K次图,做K次KM
        ans = 0 ;
        
for (k = 1 ;k <= K;k ++ ){
            l1
= l2 = 0 ;
            nx
= 0 ;
            memset(map,
0 , sizeof (map));
            
for (i = 1 ;i <= N;i ++ ){
                ny
= 0 ;
                l1
= shopkeeper[i][k];
                flag
= false ;
                
for (j = 1 ;j <= M;j ++ ){
                    l2
= supply[j][k];
                    
for (ii = 1 ;ii <= l1;ii ++ ){
                        
for (jj = 1 ;jj <= l2;jj ++ ){
                            flag
= true ;
                            map[nx
+ ii][ny + jj] =- cost[k][i][j];
                        }
                    }
                    
if (l2)
                        ny
+= l2;
                }
                
if (flag)
                    nx
+= l1;
            }

            KM();
            res
= 0 ;
            
for (i = 1 ;i <= nx;i ++ )
                res
+= map[i][xm[i]];
            
            ans
-= res;
        }
        printf(
" %d\n " ,ans);
    
    }
    
return   0 ;
}

转载于:https://www.cnblogs.com/zgmf_x20a/archive/2009/02/02/1382502.html

以下是对提供的参考资料的总结,按照要求结构化多个要点分条输出: 4G/5G无线网络优化与网规案例分析: NSA站点下终端掉4G问题:部分用户反馈NSA终端频繁掉4G,主要因终端主动发起SCGfail导致。分析显示,在信号较好的环境下,终端可能因节能、过热保护等原因主动释放连接。解决方案建议终端侧进行分析处理,尝试关闭节电开关等。 RSSI算法识别天馈遮挡:通过计算RSSI平均值及差值识别天馈遮挡,差值大于3dB则认定有遮挡。不同设备分组规则不同,如64T和32T。此方法可有效帮助现场人员识别因环境变化引起的网络问题。 5G 160M组网小区CA不生效:某5G站点开启100M+60M CA功能后,测试发现UE无法正常使用CA功能。问题原因在于CA频点集标识配置错误,修正后测试正常。 5G网络优化与策略: CCE映射方式优化:针对诺基亚站点覆盖农村区域,通过优化CCE资源映射方式(交织、非交织),提升RRC连接建立成功率和无线接通率。非交织方式相比交织方式有显著提升。 5G AAU两扇区组网:与三扇区组网相比,AAU两扇区组网在RSRP、SINR、下载速率和上传速率上表现不同,需根据具体场景选择适合的组网方式。 5G语音解决方案:包括沿用4G语音解决方案、EPS Fallback方案和VoNR方案。不同方案适用于不同的5G组网策略,如NSA和SA,并影响语音连续性和网络覆盖。 4G网络优化与资源利用: 4G室分设备利旧:面对4G网络投资压减与资源需求矛盾,提出利旧多维度调优策略,包括资源整合、统筹调配既有资源,以满足新增需求和提质增效。 宏站RRU设备1托N射灯:针对5G深度覆盖需求,研究使用宏站AAU结合1托N射灯方案,快速便捷地开通5G站点,提升深度覆盖能力。 基站与流程管理: 爱立信LTE基站邻区添加流程:未提供具体内容,但通常涉及邻区规划、参数配置、测试验证等步骤,以确保基站间顺畅切换和覆盖连续性。 网络规划与策略: 新高铁跨海大桥覆盖方案试点:虽未提供详细内容,但可推测涉及高铁跨海大桥区域的4G/5G网络覆盖规划,需考虑信号穿透、移动性管理、网络容量等因素。 总结: 提供的参考资料涵盖了4G/5G无线网络优化、网规案例分析、网络优化策略、资源利用、基站管理等多个方面。 通过具体案例分析,展示了无线网络优化中的常见问题及解决方案,如NSA终端掉4G、RSSI识别天馈遮挡、CA不生效等。 强调了5G网络优化与策略的重要性,包括CCE映射方式优化、5G语音解决方案、AAU扇区组网选择等。 提出了4G网络优化与资源利用的策略,如室分设备利旧、宏站RRU设备1托N射灯等。 基站与流程管理方面,提到了爱立信LTE基站邻区添加流程,但未给出具体细节。 新高铁跨海大桥覆盖方案试点展示了特殊场景下的网络规划需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值