Блог пользователя NguyenKhacTrung

Автор NguyenKhacTrung, история, 13 месяцев назад, По-английски

i have the problem knapsack has condition N<=100 and w,v<=10^9.

  • Проголосовать: нравится
  • +7
  • Проголосовать: не нравится

»
13 месяцев назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

Any other condition specified? Probably there's.

»
13 месяцев назад, # |
Rev. 2   Проголосовать: нравится +14 Проголосовать: не нравится

This one has a extra condition $$$w\times v\le 10^9$$$, and I don’t think the problem is solvable without this condition.

»
13 месяцев назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

Could you please add the link? Or the full statement?

»
13 месяцев назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

The problem probably has some other stuff if it is meant to be solvable with this range of values. The best you can do with a small $$$N$$$ would be "meet in the middle", which will still be a TLE if your $$$N \leq 100$$$

»
13 месяцев назад, # |
  Проголосовать: нравится -10 Проголосовать: не нравится

Vip pro ngừi Việt. As far as i know there's a solution with $$$O(n\sqrt{totalweight})$$$ complexity. So with $$$totalweight=n*w= 1e11$$$ then yeah this solution passes. The idea is that there are about $$$\sqrt{w}$$$ possible sums of subsets when the sum of all of the elements in the set equal $$$w$$$ so we just need to calculate all those possible sums first, then apply the general dp algorithm -> $$$O(n\sqrt{sum})$$$ instead of $$$O(n*sum)$$$. How? I havent implemented it myself but this blog exlains it well and also provides an implementation :D https://codeforces.net/blog/entry/97396

  • »
    »
    13 месяцев назад, # ^ |
    Rev. 2   Проголосовать: нравится +3 Проголосовать: не нравится

    How is that true? Pick elements: $$$1, 2, 4, 8, 16, 32, \ldots, 2^n$$$. Each number from $$$[0, 2^{n+1})$$$ can be obtained as a sum of some subset. We have sum $$$w = 2^{n+1} - 1$$$ and $$$w + 1$$$ possible sums of subsets.

  • »
    »
    13 месяцев назад, # ^ |
      Проголосовать: нравится +3 Проголосовать: не нравится

    You did not understand that blog. N in that blog is the sum (or maybe more precisely the sum being O(N)). That'd give us O(totalweight^1.5) in here, which is obviously useless.

    • »
      »
      »
      13 месяцев назад, # ^ |
      Rev. 2   Проголосовать: нравится +15 Проголосовать: не нравится

      Yeah you are right, my sincere apologies, I didn't read the blog carefully, what a shame.

»
13 месяцев назад, # |
  Проголосовать: нравится 0 Проголосовать: не нравится

Can you add a link to the problem?