結果
問題 | No.17 2つの地点に泊まりたい |
ユーザー | akakimidori |
提出日時 | 2018-07-08 02:13:35 |
言語 | C90 (gcc 11.4.0) |
結果 |
AC
|
実行時間 | 1 ms / 5,000 ms |
コード長 | 931 bytes |
コンパイル時間 | 243 ms |
コンパイル使用メモリ | 23,936 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-10-15 04:08:23 |
合計ジャッジ時間 | 966 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 1 ms
5,248 KB |
testcase_01 | AC | 1 ms
5,248 KB |
testcase_02 | AC | 1 ms
5,248 KB |
testcase_03 | AC | 0 ms
5,248 KB |
testcase_04 | AC | 1 ms
5,248 KB |
testcase_05 | AC | 1 ms
5,248 KB |
testcase_06 | AC | 1 ms
5,248 KB |
testcase_07 | AC | 1 ms
5,248 KB |
testcase_08 | AC | 1 ms
5,248 KB |
testcase_09 | AC | 1 ms
5,248 KB |
testcase_10 | AC | 1 ms
5,248 KB |
testcase_11 | AC | 1 ms
5,248 KB |
testcase_12 | AC | 1 ms
5,248 KB |
testcase_13 | AC | 0 ms
5,248 KB |
testcase_14 | AC | 1 ms
5,248 KB |
testcase_15 | AC | 0 ms
5,248 KB |
testcase_16 | AC | 0 ms
5,248 KB |
testcase_17 | AC | 1 ms
5,248 KB |
testcase_18 | AC | 1 ms
5,248 KB |
testcase_19 | AC | 1 ms
5,248 KB |
testcase_20 | AC | 1 ms
5,248 KB |
testcase_21 | AC | 1 ms
5,248 KB |
testcase_22 | AC | 1 ms
5,248 KB |
testcase_23 | AC | 0 ms
5,248 KB |
testcase_24 | AC | 1 ms
5,248 KB |
testcase_25 | AC | 1 ms
5,248 KB |
testcase_26 | AC | 1 ms
5,248 KB |
コンパイルメッセージ
main.c: In function ‘run’: main.c:15:3: warning: ignoring return value of ‘scanf’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 15 | scanf("%d",&n); | ^~~~~~~~~~~~~~ main.c:18:20: warning: ignoring return value of ‘scanf’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 18 | for(i=0;i<n;i++) scanf("%d",s+i); | ^~~~~~~~~~~~~~~ main.c:20:3: warning: ignoring return value of ‘scanf’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 20 | scanf("%d",&m); | ^~~~~~~~~~~~~~ main.c:26:5: warning: ignoring return value of ‘scanf’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 26 | scanf("%d%d%d",&a,&b,&cc); | ^~~~~~~~~~~~~~~~~~~~~~~~~
ソースコード
#include<stdio.h> #include<stdlib.h> #include<math.h> typedef long long int int64; #define MAX(a,b) ((a)>(b)?(a):(b)) #define MIN(a,b) ((a)<(b)?(a):(b)) #define ABS(a) ((a)>(0)?(a):-(a)) #define POS(i,j) ((i)*n+(j)) void run(void){ int n; scanf("%d",&n); int s[50]; int i,j,k; for(i=0;i<n;i++) scanf("%d",s+i); int m; scanf("%d",&m); const int inf=100000; int c[2500]; for(i=0;i<n;i++) for(j=0;j<n;j++) c[POS(i,j)]=(i==j)?0:inf; for(i=0;i<m;i++){ int a,b,cc; scanf("%d%d%d",&a,&b,&cc); c[POS(a,b)]=cc; c[POS(b,a)]=cc; } for(k=0;k<n;k++){ for(i=0;i<n;i++){ for(j=0;j<n;j++){ c[POS(i,j)]=MIN(c[POS(i,j)],c[POS(i,k)]+c[POS(k,j)]); } } } int min=inf; for(i=1;i<n-1;i++){ for(j=1;j<n-1;j++){ if(i==j) continue; min=MIN(min,c[POS(0,i)]+s[i]+c[POS(i,j)]+s[j]+c[POS(j,n-1)]); } } printf("%d\n",min); } int main(void){ run(); return 0; }