結果

問題 No.406 鴨等間隔の法則
ユーザー monburan_0401monburan_0401
提出日時 2018-09-15 17:04:50
言語 C
(gcc 12.3.0)
結果
AC  
実行時間 27 ms / 2,000 ms
コード長 1,068 bytes
コンパイル時間 196 ms
コンパイル使用メモリ 29,440 KB
実行使用メモリ 5,376 KB
最終ジャッジ日時 2024-07-07 12:30:13
合計ジャッジ時間 1,688 ms
ジャッジサーバーID
(参考情報)
judge1 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 11 ms
5,248 KB
testcase_01 AC 1 ms
5,376 KB
testcase_02 AC 1 ms
5,376 KB
testcase_03 AC 1 ms
5,376 KB
testcase_04 AC 24 ms
5,376 KB
testcase_05 AC 9 ms
5,376 KB
testcase_06 AC 10 ms
5,376 KB
testcase_07 AC 10 ms
5,376 KB
testcase_08 AC 24 ms
5,376 KB
testcase_09 AC 27 ms
5,376 KB
testcase_10 AC 10 ms
5,376 KB
testcase_11 AC 20 ms
5,376 KB
testcase_12 AC 14 ms
5,376 KB
testcase_13 AC 13 ms
5,376 KB
testcase_14 AC 22 ms
5,376 KB
testcase_15 AC 2 ms
5,376 KB
testcase_16 AC 3 ms
5,376 KB
testcase_17 AC 2 ms
5,376 KB
testcase_18 AC 2 ms
5,376 KB
testcase_19 AC 3 ms
5,376 KB
testcase_20 AC 4 ms
5,376 KB
testcase_21 AC 4 ms
5,376 KB
testcase_22 AC 6 ms
5,376 KB
testcase_23 AC 14 ms
5,376 KB
testcase_24 AC 19 ms
5,376 KB
testcase_25 AC 26 ms
5,376 KB
testcase_26 AC 26 ms
5,376 KB
testcase_27 AC 17 ms
5,376 KB
testcase_28 AC 18 ms
5,376 KB
testcase_29 AC 27 ms
5,376 KB
testcase_30 AC 26 ms
5,376 KB
testcase_31 AC 26 ms
5,376 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.c: In function 'main':
main.c:25:9: warning: implicit declaration of function 'qsort' [-Wimplicit-function-declaration]
   25 |         qsort(x,N,4,c);
      |         ^~~~~

ソースコード

diff #

#include <stdio.h>
int c(int*a,int*b){return *a - *b;}
int main(void){
	int N;
	int x[100000];
	int change;
    int d;
	
	scanf("%d",&N);
	for(int i = 0; i < N; i++){
		scanf("%d",&x[i]);
	}
	
	//	小さいものから順に並べる
/*	for(int j = 0; j < N-1; j++){
		for(int k = j; k < N; k++){
			if(x[j] > x[k]){
				change = x[j];
				x[j] = x[k];
				x[k] = change;
			}
		}
	}
*/
	qsort(x,N,4,c);
	// check ok
/*	for(int a = 0; a < N; a++){
		printf("%d ",x[a]);
	}
	printf("\n");
*/
	
/*	for(int l = N-1; l > 0; l--){
		x[l] -= x[l-1];
	}
*/
	
	// check ok
/*	for(int a = 0; a < N; a++){
		printf("%d ",x[a]);
	}
	printf("\n");
*/
    d = x[1] - x[0];		//	等差数列
    if(d == 0){
    	printf("NO\n");
    	return 0;
    }
    for(int o = 2; o < N; o++){
        x[1] += d;
        if(x[1] != x[o]){
            printf("NO\n");
            return 0;
        }
    }
	//	以降、x[0]は無視
/*	for(int m = 1; m < N-1; m++){
		if( (x[m] - x[m-1] != x[m+1] - x[m])||(x[m] == 0) ){
			printf("NO\n");
			return 0;
		}
	}
*/
	
	printf("YES\n");
	return 0;
}
0