Minimum Set Cover是一个问题,您必须找到覆盖每个元素所需的最小数量.
例如,假设我们有一组X =数组(1,2,3,4,5,6)和另一组S,其中
S[1]=array(1,4) 
S[2] =array(2,5) 
S[3] =array(3,6)
S[4] =array(1,3) 
S[5] =array(4,6)

问题是找到覆盖X的每一个元素的最小S集合.因此,我们这个例子中最小集合覆盖将是S [4]和S [5],因为它覆盖了所有元素.
有人有一个想法如何在PHP中实现这个代码.注意,这是NP-complete,所以没有快速的算法来解决它.欢迎任何PHP解决方案.而BTW它不是一个功课,我需要在我的Web应用程序中使用这个算法,以生成建议列表.
提前致谢.

更新1
集合覆盖问题有很多应用.一些有趣的是:

>最优逻辑电路的构建
>机组人员安排
>装配线平衡
>信息检索
>美术馆问题
基因组测序
>红蓝SetCover问题

更新2
例如,here你可以看到我提到的问题的工作版本.在这里,即使它可视地显示集合.但是我需要纯PHP代码,如果有人有,请给我们提供PHP中的工作示例.谢谢

更新3
最后我用PHP解决了这个问题.我的解决方案基于这个算法提出的一本非常着名的书,叫做Introduction to Algorithms,部分集合问题.这里我的解决方案如何:

$MainSet=array(1,6,7);
$SubSet=array(array(1,4),array(2,5),array(3,6),array(1,3),array(4,6));

$UncoveredElements=$MainSet;
$CoveringSets=array();
while (count($UncoveredElements)>0){
    $S=SubSetS($UncoveredElements,$SubSet);
    if (is_array($S)){
        $UncoveredElements=array_diff($UncoveredElements,$S);
        $CoveringSets[]=$S;
    }else
        break; //finish work
}
echo "Sets that cover MainSet are:";
var_dump($CoveringSets);

//Subset S is chosen that covers as many uncovered elements as possible
function SubSetS($UncoveredElements,$SubSetArr){
    $max=0; $s=array();
    foreach($SubSetArr as $SubSet){
        $intersectArr=array_intersect($UncoveredElements,$SubSet);
        $weight=count($intersectArr);
        if ($weight>$max){
            $max=$weight;
            $s=$SubSet;
        }
    }
    if ($max>0)
        return $s;
    else
        return 0;
}

关于我的解决方案的任何意见和想法?对我来说,它解决了我的问题,就是我想要的.但是,如果您建议任何优化,更正代码,请填写免费.
BTW,非常感谢参与者的宝贵回应.

最终更新
这种用于集合覆盖问题的贪婪方法并不总是保证最佳解决方案.请考虑以下示例:
给定:主集的元素= {1,6}
现在,考虑4个子集,如下:子集1 = {1,2},子集2 = {3,4},子集3 = {5,6},子集4 = {1,5}.
以上集合的贪婪算法给出了最小集合封面:
最小集封面包含子集= {1,4}.
因此,尽管覆盖主集合的所有元素的子集的最小集合是前三个子集,但是我们得到包含所有4个子集的解.

Bakhtiyor,你所说的这个问题需要一点点矛盾.你首先说你想要一个最小的封面,并指出自己这个问题是np-hard.您发布的算法是贪心集合覆盖算法.该算法找到一个非常小的集合封面,但不一定是最小的封面.两个人发布了一个算法,搜索更彻底,确实找到一个最小的封面,你在一个评论中说,你不需要一个最佳的解决方案.

你需要一个最佳的解决方案吗?因为找到最小集合封面是一个非常不同的算法问题,因为找到一个相当小的集合封面.前者的算法必须非常仔细地写入,以免大量输入. (通过我的大输入,我的意思是说,40个子集.)后者的算法很容易,你用自己的代码做了很好的工作.我会改变的一件事是,在你的循环语句“foreach($SubSetArr as $SubSet)”之前,我将随机化子集列表.这为算法提供了许多输入的最佳选择机会. (但是,有一些例子,其中最小集合覆盖不包括最大的子集,所以对于某些输入,这个特定的贪婪算法将无法找到最小值,无论顺序如何).

如果你真的想要最小的封面,而不只是一个很好的封面,那么你应该说出你希望代码完全解决的最大的输入.这是一个关键的细节,影响算法需要为您的任务花哨.

要回应其他人的看法:首先,如果您想要最佳解决方案,则无需搜索所有子集.其次,您不应该为该问题寻找“该”算法.这个问题有很多算法,比其他算法要快一些,比其他算法复杂一些.

这里有一种方法可以从搜索所有集合的算法开始,并加速它,使之更好.我不会提供代码,因为我不认为提问者想要这样一个奇特的解决方案,但我可以描述这些想法.您可以将搜索排列为分支搜索:最佳集合覆盖包含最大子集A或不包含. (从最大的集合开始就可以正常工作.)如果是这样,您可以从元素列表中删除A的元素,从其他子集的元素中删除A的元素,并解决剩余子集覆盖问题.如果没有,您仍然可以从子集列表中删除A并解决剩余子集覆盖问题.

到目前为止,这只是一种安排搜索所有内容的方法.但是,在这种递归算法中有几种重要的方法来获取快捷方式.当您找到解决方案时,您可以保留迄今为止发现的最佳记录.这设定了你必须打败的门槛.在每个阶段,您可以总计剩余的最大阈值-1个子集的大小,并查看它们是否有足够的元素来覆盖其余的元素.如果没有,你可以放弃;你不会超过当前的门槛.

另外,如果在这个递归算法中,任何元素只被一个子集覆盖,那么你可以抛出该子集来确定它是否是最大的. (事实上​​,添加这一步甚至是Bakhtiyor编码的贪婪算法是个好主意.)

这两个加速度可以从搜索树中分离出大量的分支,并且它们组合起来更好.

由于Don knuth所谓的“跳舞链接”,这种类型的问题还有一个聪明的数据结构.他提出了一个确切的覆盖问题,这是一个有点不同于这一个,但你可以适应最小的子集覆盖和上面的所有想法.跳舞链接是一个相互链接的列表的网格,允许您检查递归搜索中的子集,而无需复制整个输入.

最小集封面[PHP]的更多相关文章

  1. 吃透移动端 Html5 响应式布局

    这篇文章主要介绍了吃透移动端 Html5 响应式布局,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  2. 如何在iOS上快速将ALAsset映像保存到磁盘?

    我正在使用ALAsset来检索这样的图像:这返回CGImageRef,我想尽快保存到磁盘…解决方案1:解决方案2:问题是两种方法在设备上的执行速度都很慢.每张图片大约需要2秒才能执行此操作.这绝对是长久的.问题:如何加快图像保存过程?或许还有更好的解决方案吗?

  3. ios – 根据大小类更改约束的乘数

    根据当前的大小类,可以给出一个不同乘数的约束吗?我有一个看法,我想要的是一般尺寸类宽度的一半的屏幕尺寸,我希望它是一个紧凑的尺寸类宽度的屏幕尺寸的80%.在故事板中,我可以选择将不同大小的类别的不同变量添加到约束常量值,但不是乘数值.这是相等的宽度限制.我没有在程序上添加约束,所以我希望他们可能是一个解决方案,在这条路上.任何人都可以告诉我是否可以通过故事板或编程方式来做我正在寻找的内容?

  4. 是否可以从我的iOS应用程序包中删除文件?

    解决方法无法删除捆绑包中的文件.必须对应用程序进行签名,如果以任何方式修改了包,它将不会通过签名.我能想到的唯一其他解决方案是设置Web服务,并让您的应用程序根据需要下载部分内容.这可能是也可能不是可行的解决方案,具体取决于您的应用实际执行的操作.

  5. 用Swift实现MD5算法&引入第三方类库MBProgressHUD

    之前项目里面是用objc写的MD5加密算法,最近在用swift重写以前的项目,遇到了这个问题。顺带解决掉的还有如何引入第三方的类库,例如MBProgressHUD等一些特别好的控件解决的方法其实是用objc和swift混合编程的方法,利用Bridging-header文件。你可以简单的理解为在一个用swift语言开发的工程中,引入objective-c文件是需要做的一个串联文件,好比架设了一个桥,让swift中也可以调用objective-c的类库和frame等等。

  6. Swift40/90Days - 用函数式编程解决逻辑难题

    Swift90Days-用函数式编程解决逻辑难题这篇翻译的文章,用两种方法解决了同一个逻辑难题。第二种方法利用了Swift的一些语言特性,实现了函数式编程的解决方案。这样的代码对于指令式编程来说再平常不过,接下来我们就来看下如何用函数式编程解决这个问题。Swift中函数已经是一等公民,这让高阶函数变成可能,也就是说,一个函数可以是通过其它函数组装构成的。思考Swift对于函数式编程的支持让我感觉的兴奋,Excited!

  7. swift排序算法和数据结构

    vararrayNumber:[Int]=[2,4,216)">6,216)">7,216)">3,216)">8,216)">1]//冒泡排序funcmaopao->[Int]{forvari=0;i

  8. 关于oc和swift混编 框架framework时 只能在真机运行或只能在模拟器单独运行的解决方案

    问题描述:关于oc和swift混编框架framework时只能在真机运行或只能在模拟器单独运行的解决方案。

  9. swift - 函数指针的应用 - 避免重复算法

    =nil;})}privatefuncsearch(selector:(Employee->Bool))->[Employee]{varresults=[Employee]();foreinemployees{if(selector(e)){results.append(e);}}returnresults;}}

  10. 如何用 Swift 实现 A* 寻路算法

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

随机推荐

  1. PHP个人网站架设连环讲(一)

    先下一个OmnihttpdProffesinalV2.06,装上就有PHP4beta3可以用了。PHP4给我们带来一个简单的方法,就是使用SESSION(会话)级变量。但是如果不是PHP4又该怎么办?我们可以假设某人在15分钟以内对你的网页的请求都不属于一个新的人次,这样你可以做个计数的过程存在INC里,在每一个页面引用,访客第一次进入时将访问时间送到cookie里。以后每个页面被访问时都检查cookie上次访问时间值。

  2. PHP函数学习之PHP函数点评

    PHP函数使用说明,应用举例,精简点评,希望对您学习php有所帮助

  3. ecshop2.7.3 在php5.4下的各种错误问题处理

    将方法内的函数,分拆为2个部分。这个和gd库没有一点关系,是ecshop程序的问题。会出现这种问题,不外乎就是当前会员的session或者程序对cookie的处理存在漏洞。进过本地测试,includes\modules\integrates\ecshop.php这个整合自身会员的类中没有重写integrate.php中的check_cookie()方法导致,验证cookie时返回的username为空,丢失了登录状态,在ecshop.php中重写了此方法就可以了。把他加到ecshop.php的最后面去就可

  4. NT IIS下用ODBC连接数据库

    $connection=intodbc_connect建立数据库连接,$query_string="查询记录的条件"如:$query_string="select*fromtable"用$cur=intodbc_exec检索数据库,将记录集放入$cur变量中。再用while{$var1=odbc_result;$var2=odbc_result;...}读取odbc_exec()返回的数据集$cur。最后是odbc_close关闭数据库的连接。odbc_result()函数是取当前记录的指定字段值。

  5. PHP使用JpGraph绘制折线图操作示例【附源码下载】

    这篇文章主要介绍了PHP使用JpGraph绘制折线图操作,结合实例形式分析了php使用JpGraph的相关操作技巧与注意事项,并附带源码供读者下载参考,需要的朋友可以参考下

  6. zen_cart实现支付前生成订单的方法

    这篇文章主要介绍了zen_cart实现支付前生成订单的方法,结合实例形式详细分析了zen_cart支付前生成订单的具体步骤与相关实现技巧,需要的朋友可以参考下

  7. Thinkphp5框架实现获取数据库数据到视图的方法

    这篇文章主要介绍了Thinkphp5框架实现获取数据库数据到视图的方法,涉及thinkPHP5数据库配置、读取、模型操作及视图调用相关操作技巧,需要的朋友可以参考下

  8. PHP+jquery+CSS制作头像登录窗(仿QQ登陆)

    本篇文章介绍了PHP结合jQ和CSS制作头像登录窗(仿QQ登陆),实现了类似QQ的登陆界面,很有参考价值,有需要的朋友可以了解一下。

  9. 基于win2003虚拟机中apache服务器的访问

    下面小编就为大家带来一篇基于win2003虚拟机中apache服务器的访问。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  10. Yii2中组件的注册与创建方法

    这篇文章主要介绍了Yii2之组件的注册与创建的实现方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下

返回
顶部