結果
| 問題 | No.135 とりあえず1次元の問題 |
| コンテスト | |
| ユーザー |
monburan_0401
|
| 提出日時 | 2018-09-15 15:56:02 |
| 言語 | C(gnu17) (gcc 15.2.0) |
| 結果 |
CE
(最新)
AC
(最初)
|
| 実行時間 | - |
| コード長 | 739 bytes |
| 記録 | |
| コンパイル時間 | 135 ms |
| コンパイル使用メモリ | 31,556 KB |
| 最終ジャッジ日時 | 2026-02-22 01:47:19 |
|
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
コンパイルメッセージ
main.c: In function 'main':
main.c:28:23: error: passing argument 4 of 'qsort' from incompatible pointer type [-Wincompatible-pointer-types]
28 | qsort(num,N,4,c);
| ^
| |
| int (*)(int *, int *)
In file included from main.c:3:
/usr/include/stdlib.h:971:34: note: expected '__compar_fn_t' {aka 'int (*)(const void *, const void *)'} but argument is of type 'int (*)(int *, int *)'
971 | __compar_fn_t __compar) __nonnull ((1, 4));
| ~~~~~~~~~~~~~~^~~~~~~~
main.c:4:5: note: 'c' declared here
4 | int c(int*a,int*b){return*a-*b;}
| ^
/usr/include/stdlib.h:948:15: note: '__compar_fn_t' declared here
948 | typedef int (*__compar_fn_t) (const void *, const void *);
| ^~~~~~~~~~~~~
ソースコード
#include <stdio.h>
#include <math.h>
#include <stdlib.h>
int c(int*a,int*b){return*a-*b;}
int main(void){
int N;
int num[100000];
int min = 10000000; // 求める最小値
int L; // 差の絶対値(2点間の距離)
scanf("%d",&N);
for(int i = 0; i < N; i++){
scanf("%d",&num[i]);
}
/* int change;
for(int i = 0; i < N-1; i++){
for(int j = i; j < N; j++){
if(num[i] > num[j]){
change = num[i];
num[i] = num[j];
num[j] = change;
}
}
}
*/
qsort(num,N,4,c);
for(int k = 0; k < N-1; k++){
L = abs(num[k+1] - num[k]);
if( (min > L)&&(L != 0) ){
min = L;
}
}
if(min == 10000000){
min = 0;
}
printf("%d\n",min);
return 0;
}
monburan_0401