百科问答小站 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。




  

相关话题

  27岁想转python,是否值得? 
  如何向一个零基础的人,解释学习计算机编程的正确顺序和原因? 
  无代码编程会是以后的趋势吗? 
  热爱互联网,想到硅谷去工作有哪些办法? 
  几个 G 大的 Windows 操作系统纯代码核心部分有多大? 
  程序员可以去spaceX 工作么? 
  面试题目很简单,但还是被拒了。如何询问真正原因? 
  什么理由让代码保存为GBK? 
  如何评价即将在 Connect(); 2016 上亮相的 Visual Studio for Mac? 
  C++ 实现接口与实现分离后,文件变得更多了,到底有什么好处? 

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





© 2025-04-26 - tinynew.org. All Rights Reserved.
© 2025-04-26 - tinynew.org. 保留所有权利