結果
| 問題 |
No.2232 Miser's Gift
|
| コンテスト | |
| ユーザー |
tails
|
| 提出日時 | 2023-03-03 22:56:58 |
| 言語 | C90 (gcc 12.3.0) |
| 結果 |
AC
|
| 実行時間 | 6 ms / 2,000 ms |
| コード長 | 749 bytes |
| コンパイル時間 | 1,173 ms |
| コンパイル使用メモリ | 27,520 KB |
| 実行使用メモリ | 6,948 KB |
| 最終ジャッジ日時 | 2024-09-18 00:06:29 |
| 合計ジャッジ時間 | 3,584 ms |
|
ジャッジサーバーID (参考情報) |
judge6 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 55 |
コンパイルメッセージ
main.c: In function ‘f2’:
main.c:35:9: warning: implicit declaration of function ‘write’ [-Wimplicit-function-declaration]
35 | write(1,wp,wbuf+sizeof wbuf-wp);
| ^~~~~
main.c: In function ‘main’:
main.c:40:9: warning: implicit declaration of function ‘_exit’ [-Wimplicit-function-declaration]
40 | _exit(0);
| ^~~~~
main.c:40:9: warning: incompatible implicit declaration of built-in function ‘_exit’ [-Wbuiltin-declaration-mismatch]
ソースコード
#pragma GCC optimize("Ofast")
#pragma GCC target("avx2")
#define getrp() ({char*mmap();mmap(0l,1l<<25,1,2,0,0ll);})
#define rd_skip() while(*rp++>=48)
#define rd() ({int _v=0,_c;while(_c=*rp++-48,_c>=0)_v=_v*10+_c;_v;})
#define wt(v) ({unsigned _z=v;do*--wp=_z%10+48;while(_z/=10);})
#define rep(v,e) for(int v=0;v<e;++v)
#define rrep(v,e) for(int v=e;--v>=0;)
#define chmax(v,a) (v=v>=a?v:a)
char wbuf[1<<25];
int d[100001];
int f1(){
char*rp=getrp();
rd_skip();
int w=rd();
while(*rp){
int x=rd();
int v=rd();
rrep(i,w+1-x){
chmax(d[i+x],d[i]+v);
}
}
return w;
}
void f2(int w){
char*wp=wbuf+sizeof wbuf;
rep(i,w){
*--wp='\n';
wt(d[w]-d[i]+1);
}
write(1,wp,wbuf+sizeof wbuf-wp);
}
int main(){
f2(f1());
_exit(0);
}
tails