結果
| 問題 | No.178 美しいWhitespace (1) |
| コンテスト | |
| ユーザー |
monburan_0401
|
| 提出日時 | 2018-09-18 16:17:37 |
| 言語 | C(gnu17) (gcc 15.2.0) |
| 結果 |
CE
(最新)
AC
(最初)
|
| 実行時間 | - |
| コード長 | 652 bytes |
| 記録 | |
| コンパイル時間 | 87 ms |
| コンパイル使用メモリ | 28,096 KB |
| 最終ジャッジ日時 | 2026-02-22 01:51:03 |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
コンパイルメッセージ
main.c: In function 'main':
main.c:18:21: error: passing argument 4 of 'qsort' from incompatible pointer type [-Wincompatible-pointer-types]
18 | qsort(C,N,8,c); // (配列、データ数、1つのメモリ、並び順)
| ^
| |
| int (*)(int *, int *)
In file included from main.c:2:
/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;} // これを long でも通用するように
| ^
/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 <stdlib.h>
int c(int*a,int*b){return*a-*b;} // これを long でも通用するように
int main(void){
int N;
int a,b;
long int C[1000];
long int count = 0;
scanf("%d",&N);
for(int i = 0; i < N; i++){
scanf("%d %d",&a,&b);
C[i] = a + b * 4;
}
qsort(C,N,8,c); // (配列、データ数、1つのメモリ、並び順)
// check ok
/* for(int k = 0; k < N; k++){
printf("%d ",C[k]);
}
printf("\n");
*/
for(int j = 0; j < N-1; j++){
if( (C[j+1] - C[j]) % 2 != 0 ){
printf("-1\n");
return 0;
}else{
count += (C[j+1] - C[j]) / 2 * (j+1);
}
}
printf("%ld\n",count);
return 0;
}
monburan_0401