百科问答小站 logo
百科问答小站 font logo



这个号称「微软的面试题」,该如何解答? 第1页

  

user avatar   be5invis 网友的相关建议: 
      

什么时候加上了绝对值……

带绝对值就是 Partition Problem 了,有一个伪多项式的 DP 算法,思路大概是这样的:

       var cache = ...; function P(a, j, l, s) { // a[0..j] 中有长度为 l 且总和为 s 的子集吗?     if(cache.has(j, l, s)) return cache.find(j, l, s) // 缓存     if(l === 0 && s === 0) return cache.save(j, l, s, true);     if(l === 0 && s !== 0 || j === 0 && l > 0 || j === 0 && s !== 0) return cache.save(j, l, s, false);     return cache.save(j, l, s, P(a, j - 1, l, s) || P(a, j - 1, l - 1, s - a[j - 1])) }  for(var s = Math.floor((sum(a) + sum(b)) / 2); s >= 0; s--){     if(P(a.concat(b), n * 2, n, s)) { ... } }      

不带绝对值的话

先要说清楚定义,因为如果只能交换 ab 中的对应项,那么很简单的贪心法就能解决;如果可以多次任意交换,那么就是排序完切割;如果是一次交换若干对的话,是 2n×2n 的二分图最佳匹配,用 KM。




  

相关话题

  中国的程序员群体是否已经过多了? 
  如何评价微软 CEO 纳德拉说「收购诺基亚是失败的」? 
  你见过哪些令你瞠目结舌的 Python 代码技巧? 
  如何看待这份2018互联网校招高薪清单? 
  360 公司的员工怎么看待自己公司的产品?听到差评会尴尬吗? 
  Minecraft 会以什么方式没落? 
  什么是 hash? 
  90%的程序员认为编程其乐无穷? 
  有哪些有趣的反爬虫手段? 
  计算机基础知识对程序员来说有多重要? 

前一个讨论
如何评价微软2016年3月18日Windows 10 Mobile推送放弃绝大多数旧机型的决定?
下一个讨论
如何评价微软PowerShell将支持SSH?





© 2025-01-03 - tinynew.org. All Rights Reserved.
© 2025-01-03 - tinynew.org. 保留所有权利