結果

問題 No.1581 Multiple Sequence
ユーザー tailstails
提出日時 2021-07-06 09:23:57
言語 C
(gcc 12.3.0)
結果
AC  
実行時間 3 ms / 2,000 ms
コード長 833 bytes
コンパイル時間 597 ms
コンパイル使用メモリ 30,592 KB
実行使用メモリ 6,944 KB
最終ジャッジ日時 2024-07-01 12:05:32
合計ジャッジ時間 959 ms
ジャッジサーバーID
(参考情報)
judge4 / judge5
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 3 ms
6,812 KB
testcase_01 AC 3 ms
6,940 KB
testcase_02 AC 3 ms
6,944 KB
testcase_03 AC 3 ms
6,940 KB
testcase_04 AC 3 ms
6,944 KB
testcase_05 AC 3 ms
6,940 KB
testcase_06 AC 3 ms
6,940 KB
testcase_07 AC 3 ms
6,944 KB
testcase_08 AC 3 ms
6,944 KB
testcase_09 AC 3 ms
6,944 KB
testcase_10 AC 3 ms
6,944 KB
testcase_11 AC 3 ms
6,944 KB
testcase_12 AC 3 ms
6,940 KB
testcase_13 AC 3 ms
6,944 KB
testcase_14 AC 3 ms
6,940 KB
testcase_15 AC 3 ms
6,940 KB
testcase_16 AC 3 ms
6,944 KB
testcase_17 AC 3 ms
6,940 KB
testcase_18 AC 3 ms
6,944 KB
testcase_19 AC 3 ms
6,940 KB
testcase_20 AC 3 ms
6,940 KB
testcase_21 AC 3 ms
6,944 KB
testcase_22 AC 3 ms
6,940 KB
testcase_23 AC 3 ms
6,944 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.c:13:1: warning: return type defaults to 'int' [-Wimplicit-int]
   13 | main(){
      | ^~~~
main.c: In function 'main':
main.c:46:9: warning: implicit declaration of function 'read'; did you mean 'rd'? [-Wimplicit-function-declaration]
   46 |         read(0,rp,sizeof buf);
      |         ^~~~
      |         rd
main.c:50:9: warning: implicit declaration of function 'write' [-Wimplicit-function-declaration]
   50 |         write(1,wp,buf+sizeof buf-wp);
      |         ^~~~~
main.c:51:9: warning: implicit declaration of function '_exit'; did you mean '_Exit'? [-Wimplicit-function-declaration]
   51 |         _exit(0);
      |         ^~~~~
      |         _Exit

ソースコード

diff #

#pragma GCC optimize("Ofast")
#pragma GCC target("avx2")

char*mmap();
#define rd(v) long v=0;{int _c;while(_c=*rp++-48,_c>=0)v=v*10+_c;}
#define wt(v) {long _z=v;do*--wp=_z%10+48;while(_z/=10);}

#define MD 1000000007

#define LIM 100000
long dp[LIM+20];

main(){
	long*p=dp+1;
	for(long j=1;j<=LIM;j+=12){
		*p++=1;
		*p++=2;
		*p++=3;
		*p++=5;
		*p++=1;
		*p++=4;
		*p++=1;
		*p++=5;
		*p++=3;
		*p++=2;
		*p++=1;
		*p++=7;
	}
	for(long i=5;i<=10000;++i){
		long a=dp[i-1];
		for(long j=i;j<=LIM;j+=i){
			dp[j]+=a;
		}
	}
	for(long i=10001;i<=LIM/2;++i){
		long a=dp[i-1]%MD;
		for(long j=i;j<=LIM;j+=i){
			dp[j]+=a;
		}
	}
	for(long i=LIM/2+1;i<=LIM;++i){
		dp[i]+=dp[i-1]%MD;
	}
	char buf[64];
	char*rp=buf;
	read(0,rp,sizeof buf);
	rd(m);
	char*wp=buf+sizeof buf;
	wt(dp[m]%MD);
	write(1,wp,buf+sizeof buf-wp);
	_exit(0);
}
0