結果

問題 No.689 E869120 and Constructing Array 3
ユーザー testestesttestestest
提出日時 2018-05-27 19:37:05
言語 C
(gcc 12.3.0)
結果
AC  
実行時間 2 ms / 1,000 ms
コード長 672 bytes
コンパイル時間 145 ms
コンパイル使用メモリ 29,628 KB
実行使用メモリ 4,380 KB
最終ジャッジ日時 2023-09-11 04:43:41
合計ジャッジ時間 1,662 ms
ジャッジサーバーID
(参考情報)
judge13 / judge11
このコードへのチャレンジ(β)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
4,380 KB
testcase_01 AC 1 ms
4,376 KB
testcase_02 AC 1 ms
4,376 KB
testcase_03 AC 2 ms
4,380 KB
testcase_04 AC 1 ms
4,380 KB
testcase_05 AC 1 ms
4,380 KB
testcase_06 AC 2 ms
4,376 KB
testcase_07 AC 2 ms
4,376 KB
testcase_08 AC 1 ms
4,376 KB
testcase_09 AC 1 ms
4,380 KB
testcase_10 AC 2 ms
4,376 KB
testcase_11 AC 1 ms
4,376 KB
testcase_12 AC 2 ms
4,380 KB
testcase_13 AC 2 ms
4,376 KB
testcase_14 AC 2 ms
4,380 KB
testcase_15 AC 1 ms
4,376 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.c:10:1: 警告: 戻り値の型をデフォルトの ‘int’ にします [-Wimplicit-int]
   10 | maekeisann(){
      | ^~~~~~~~~~
main.c:27:1: 警告: 戻り値の型をデフォルトの ‘int’ にします [-Wimplicit-int]
   27 | f(ll k){
      | ^
main.c: 関数 ‘f’ 内:
main.c:29:17: 警告: 関数 ‘sqrt’ の暗黙的な宣言です [-Wimplicit-function-declaration]
   29 |         ll temp=sqrt(k);
      |                 ^~~~
main.c:1:1: 備考: include ‘<math.h>’ or provide a declaration of ‘sqrt’
  +++ |+#include <math.h>
    1 | #define ll long long
main.c:29:17: 警告: 組み込み関数 ‘sqrt’ の互換性がない暗黙的な宣言です [-Wbuiltin-declaration-mismatch]
   29 |         ll temp=sqrt(k);
      |                 ^~~~
main.c:29:17: 備考: include ‘<math.h>’ or provide a declaration of ‘sqrt’
main.c: トップレベル:
main.c:36:1: 警告: 戻り値の型をデフォルトの ‘int’ にします [-Wimplicit-int]
   36 | main(){
      | ^~~~
main.c: 関数 ‘main’ 内:
main.c:39:9: 警告: 関数 ‘scanf’ の暗黙的な宣言です [-Wimplicit-function-declaration]
   39 |         scanf("%lld",&k);
      |         ^~~~~
main.c:1:1: 備考: include ‘<stdio.h>’ or provide a declaration of ‘scanf’
  +++ |+#include <stdio.h>
    1 | #define ll long long
main.c:39:9: 警告: 組み込み関数 ‘scanf’ の互換性がない暗黙的な宣言です [-Wbuiltin-declaration-mismatch]
   39 |         scanf("%lld",&k);
      |         ^~~~~
main.c:39:9: 備考: include ‘<stdio.h>’ or provide a declaration of ‘scanf’
main.c:41:9: 警告: 関数 ‘printf’ の暗黙的な宣言です [-Wimplicit-function-declaration]
   41 |         printf("%d\n",n*2);
      |         ^~~~~~
main.c:41:9: 備考: include ‘<stdio.h>’ or provide a declaration of ‘printf’
main.c:41:9: 警告: 組み込み関数 ‘printf’ の互換性がない暗黙的な宣言です [-Wbuiltin-declaration-mism

ソースコード

diff #

#define ll long long
#define rep(i,l,r)for(ll i=(l);i<(r);i++)

int isp(ll n){
	for(ll i=2;i*i<=n;i++)if(n%i==0)return 0;
	return 1;
}

ll a[2][50];
maekeisann(){
	a[0][0]=3;
	a[1][0]=2;
	ll cnt=1;
	for(ll c=3;c<1000;c++)if(isp(c+c+1)){
		int f=1;
		rep(i,0,cnt)if(isp(c+  a[  c%2][i]))f=0;
		rep(i,0,cnt)if(isp(c+1+a[1-c%2][i]))f=0;
		if(f){
			a[0][cnt]=c%2?c:c+1;
			a[1][cnt]=c%2?c+1:c;
			cnt++;
		}
	}
}

ll ans[50],len,n;
f(ll k){
	if(k==0)return 0;
	ll temp=sqrt(k);
	k-=temp*temp;
	ans[len++]=temp;
	n+=temp;
	f(k);
}

main(){
	maekeisann();
	ll k;
	scanf("%lld",&k);
	f(k);
	printf("%d\n",n*2);
	rep(i,0,len)rep(j,0,ans[i])printf("%lld %lld ",a[0][i],a[1][i]);
}
0