N 비트 정수 곱셈 오버플로 계산


16

양의 정수 감안할 때 N, 출력을 정수 쌍의 수 0 <= a <= b < 2**N그러한가 a*b >= 2**N.

규칙

  • 당신은 그 가정 할 수있다 N(C 예 : 또는 언어에서 정수의 최대 비트 폭과 동일 11보다 N초과하지 않습니다 32또는 64시스템의 아키텍처에 따라). 언어가 임의의 너비 정수를 처리 할 수있는 경우에는 상한이 없습니다 N.

테스트 사례

1 0
2 3
3 19
4 96
5 437
6 1876
7 7804
8 31904
9 129170
10 520135
11 2088143
12 8369175
13 33512744
14 134128704
15 536681553
16 2147082274

참고 : 지금은 더 큰 테스트 사례를 생성하고 있습니다. 나의 무차별 접근 방식은 정말 느립니다.
Mego

@ user202729 a <= b조건 을 따르지 않아 일부 쌍을 복제하고 있습니다.
Mego

1
더 많은 테스트 {0, 3, 19, 96, 437, 1876, 7804, 31904, 129170, 520135, 2088143, 8369175, 33512744, 134128704, 536681553, 2147082274, 8589086503, 34357951447}
사례

1
이 문제에 대한 폐쇄 형 공식이 없을 가능성이 있습니까? 나는 뭔가를 놓쳤을 것입니다.

1
밀접하게 관련 : en.wikipedia.org/wiki/Divisor_summatory_function를 . 알려진 닫힌 양식이 없습니다.
orlp

답변:


8

파이썬 2, 75 68 바이트

n=input()
a=1<<n
s=~-a*a/2
x=y=0
while y<1:s+=y;x-=1;y=a/x-x
print s

온라인으로 사용해보십시오!

이것은 O (2 n ) 또는 O (2 2 · n ) 대신 O (2 n / 2 ) 연산 에서 실행 되므로 훨씬 더 큰 입력에서 작동합니다.

(더 빠른 O (2 n / 3 ) 알고리즘 이 존재합니다.)

1 0
2 3
3 19
4 96
5 437
6 1876
7 7804
8 31904
9 129170
10 520135
11 2088143
12 8369175
13 33512744
14 134128704
15 536681553
16 2147082274
17 8589086503
18 34357951447
19 137435198086
20 549747939928
21 2199006781125
22 8796058620153
23 35184300378083
24 140737339120148
25 562949643323164
26 2251799170232606
27 9007197921321922
28 36028794259096612
29 144115182370060793
30 576460740519709546
31 2305842984902014765
32 9223371986742908935
33 36893488044218344323
34 147573952377320833218
35 590295809922086353118
36 2361183240537767708679
37 9444732963897547996897
38 37778931859178411534913
39 151115727444080615797321
40 604462909791437463796926
41 2417851639196741979223299
42 9671406556850476410936322
43 38685626227531971124247499
44 154742504910394112443480979
45 618970019642121099638818409
46 2475880078569598086230187969
47 9903520314280668496162705117
48 39614081257127323838921620439
49 158456325028518790167805606609
50 633825300114094540502620959956
51 2535301200456417702087608942034
52 10141204801825751449333352568660
53 40564819207303170200956592005599
54 162259276829213015854387448792578
55 649037107316852746005301421147606
56 2596148429267412374169967907532731
57 10384593717069652326923914077600197
58 41538374868278615068076777292632146
59 166153499473114471992855423428749242
60 664613997892457911812090466987383188
61 2658455991569831695728843704244440740
62 10633823966279326881474627069404687424
63 42535295865117307726213589942623257944

아주 좋은 개선!

2
당신은 교체 할 수 있습니다 x=0;y=0에 대한x=y=0
Cyoce

2^{N/3}솔루션 을 구현하면 매우 멋집니다 .

1
전체 프로그램은 4 바이트 더 짧습니다.
Dennis

1
일부 부호를 바꾸면 1 바이트가 더 절약됩니다. tio.run/…
Dennis

6

젤리 , 12 10 바이트

2*ṖµṀ:«ạ¹S

결합 된 테스트 사례를 3 초 안에 완료합니다.

온라인으로 사용해보십시오!

작동 원리

2*ṖµṀ:«ạ¹S  Main link. Argument: n

2*          Yield 2ⁿ.
  Ṗ         Pop; yield A := [1, ..., 2ⁿ-1].
   µ        New monadic chain. Argument: A
    Ṁ       Maximum; yield 2ⁿ-1.
     :      Divide 2ⁿ-1 by each k in A.
      «     Dyadic minimum; yield min((2ⁿ-1)/k, k) for each k in A.
        ¹   Identity; yield A.
       ạ    Absolute difference; yield k - min((2ⁿ-1)/k, k) for each k in A.
         S  Take the sum.

5

MATL , 10 9 바이트

Wqt:&*R<z

온라인으로 사용해보십시오!

이것은 가능한 모든 쌍을 시도합니다. 입력을 초과하는 온라인 인터프리터의 메모리가 부족 12합니다.

설명

W      % Implicitly input N. Push 2^N ('^' denotes power)
q      % Subtract 1: gives 2^N-1
t:     % Duplicate, range: pushes [0 1 2 ... 2^N-1]
&*     % Matrix of all pair-wise products
R      % Upper triangular part (including diagonal)
<      % Less-than comparison; element-wise. This gives true for products
       % that are greater than 2^N-1
z      % Number of non-zeros- Implicitly display


3

05AB1E , 13 12 바이트

Emigna 덕분에 -1 바이트

oDL<ã€{ÙP›_O

온라인으로 사용해보십시오!

설명

oDL<ã€{ÙP›_O   Argument n
oD             2^n, push twice to the stack
  L<           List: [0 .. a]
    ã          Cartesian product with itself
     €{        Sort each element
       Ù       Uniquify
        P      Total product of each element
         ›_    Each element is greater or equal than 2^n
           O   Total sum

그냥 P여기에 충분하다.
Emigna

@Emigna 감사합니다. 나는 그것을 편집 할 것이다
kalsowerus

3

자바 스크립트 (ES7), 70 65 60 바이트

n=>[...Array(k=2**n-1)].reduce(p=>p+=k<++i*i&&i-(k/i|0),i=0)

테스트 사례


2

수학, 37 바이트

Sum[#-⌈#/a⌉~Max~a,{a,#-1}]&[2^#]&

http://sandbox.open.wolframcloud.com 에서 온라인으로 사용해보십시오 . Mathematica는 정수에 제한이 없으며이 알고리즘은 2 n 시간에 실행 되므로 크게 느립니다 n.


1

클로저, 78 바이트

#(count(for[l[(bit-shift-left 1 %)]a(range l)b(range a l):when(>=(* a b)l)]1))




당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.