結果
問題 | No.278 連続する整数の和(2) |
ユーザー |
![]() |
提出日時 | 2016-12-11 16:54:46 |
言語 | C90 (gcc 8.5.0) |
結果 |
AC
|
実行時間 | 9 ms / 2,000 ms |
コード長 | 537 bytes |
コンパイル時間 | 280 ms |
使用メモリ | 1,996 KB |
最終ジャッジ日時 | 2023-01-12 16:05:02 |
合計ジャッジ時間 | 1,215 ms |
ジャッジサーバーID (参考情報) |
judge14 / judge12 |
テストケース
テストケース表示入力 | 結果 | 実行時間 使用メモリ |
---|---|---|
testcase_00 | AC | 0 ms
1,948 KB |
testcase_01 | AC | 1 ms
1,800 KB |
testcase_02 | AC | 9 ms
1,848 KB |
testcase_03 | AC | 1 ms
1,940 KB |
testcase_04 | AC | 1 ms
1,852 KB |
testcase_05 | AC | 1 ms
1,996 KB |
testcase_06 | AC | 0 ms
1,844 KB |
testcase_07 | AC | 0 ms
1,948 KB |
testcase_08 | AC | 0 ms
1,900 KB |
testcase_09 | AC | 1 ms
1,956 KB |
testcase_10 | AC | 1 ms
1,804 KB |
testcase_11 | AC | 2 ms
1,800 KB |
testcase_12 | AC | 0 ms
1,872 KB |
testcase_13 | AC | 6 ms
1,876 KB |
testcase_14 | AC | 2 ms
1,948 KB |
testcase_15 | AC | 4 ms
1,932 KB |
testcase_16 | AC | 2 ms
1,944 KB |
testcase_17 | AC | 1 ms
1,852 KB |
ソースコード
#include<stdio.h> typedef long long int ln; void run(void){ ln n; scanf("%lld",&n); if(n%2==0){ n/=2; } ln ans=1; ln k=2; ln t=1; while(n%k==0){ t*=k; n/=k; } ans*=2*t-1; k=3; t=1; while(n%k==0){ t*=k; n/=k; } ans*=(k*t-1)/(k-1); int add=2; k=5; while(k*k<=n){ t=1; while(n%k==0){ t*=k; n/=k; } ans*=(k*t-1)/(k-1); k+=add; add^=6; } if(n>1){ ans*=n+1; } printf("%lld\n",ans); return; } int main(void){ run(); return 0; }