結果

問題 No.1077 Noelちゃんと星々4
コンテスト
ユーザー tkmst201
提出日時 2021-01-29 12:20:37
言語 C11(gcc12 gnu拡張)
(gcc 12.4.0)
コンパイル:
gcc-12 -O2 -std=gnu11 -DONLINE_JUDGE -o a.out _filename_ -lm
実行:
./a.out
結果
AC  
実行時間 2 ms / 2,000 ms
コード長 589 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 138 ms
コンパイル使用メモリ 33,224 KB
実行使用メモリ 7,848 KB
最終ジャッジ日時 2026-03-08 16:25:00
合計ジャッジ時間 829 ms
ジャッジサーバーID
(参考情報)
judge2 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 20
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.c: In function ‘main’:
main.c:20:29: warning: implicit declaration of function ‘abs’ [-Wimplicit-function-declaration]
   20 |         REP(i, cxs) dp[i] = abs(A[0] - cx[i]);
      |                             ^~~
main.c:3:1: note: include ‘<stdlib.h>’ or provide a declaration of ‘abs’
    2 | #include <math.h>
  +++ |+#include <stdlib.h>
    3 | #define FOR(i,a,b) for(int i=(a);i<(b);++i)
main.c:14:9: warning: ignoring return value of ‘scanf’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   14 |         scanf("%d", &N);
      |         ^~~~~~~~~~~~~~~
main.c:15:19: warning: ignoring return value of ‘scanf’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   15 |         REP(i, N) scanf("%d", &A[i]), exist[A[i]] = 1;
      |                   ^~~~~~~~~~~~~~~~~~

ソースコード

diff #
raw source code

#include <stdio.h>
#include <math.h>
#define FOR(i,a,b) for(int i=(a);i<(b);++i)
#define REP(i,n) FOR(i,0,n)
#define INF 1<<30;

int N;
int A[1000];
int dp[1000];
_Bool exist[10001];
int cx[1000];

int main() {
	scanf("%d", &N);
	REP(i, N) scanf("%d", &A[i]), exist[A[i]] = 1;
	
	int cxs = 0;
	REP(i, 10001) if (exist[i]) cx[cxs++] = i;
	
	REP(i, cxs) dp[i] = abs(A[0] - cx[i]);
	FOR(i, 1, N) {
		int mn = INF;
		REP(j, cxs) {
			mn = mn > dp[j] ? dp[j] : mn;
			dp[j] = mn + abs(cx[j] - A[i]);
		}
	}
	
	int ans = INF;
	REP(i, cxs) ans = ans > dp[i] ? dp[i] : ans;
	printf("%d\n", ans);
}
0