結果
問題 | No.5 数字のブロック |
ユーザー |
|
提出日時 | 2020-12-14 14:40:40 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 3 ms / 5,000 ms |
コード長 | 1,397 bytes |
コンパイル時間 | 772 ms |
コンパイル使用メモリ | 74,036 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-09-20 00:43:26 |
合計ジャッジ時間 | 1,779 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 34 |
ソースコード
#include <cctype> #include <cstdio> #include <cstring> #include <iostream> #include <stdexcept> #include <vector> #include <unistd.h> #include <algorithm> using namespace std; class Scanner { vector<char> buffer; ssize_t n_written; ssize_t n_read; public: Scanner(): buffer(1024*1024) { do_read(); } int64_t read_int() { int64_t ret = 0, sgn = 1; int ch = current_char(); while (isspace(ch)) { ch = next_char(); } if (ch == '-') { sgn = -1; ch = next_char(); } for (; isdigit(ch); ch = next_char()) ret = (ret * 10) + (ch - '0'); return sgn * ret; } private: void do_read() { ssize_t r = read(0, &buffer[0], buffer.size()); if (r < 0) { throw runtime_error(strerror(errno)); } n_written = r; n_read = 0; } inline int next_char() { ++n_read; if (n_read == n_written) { do_read(); } return current_char(); } inline int current_char() { return (n_read == n_written) ? EOF : buffer[n_read]; } }; int main() { Scanner scanner; int L = scanner.read_int(); int N = scanner.read_int(); int W[10000]; for (int i = 0; i < N; i++) { W[i] = scanner.read_int(); } sort(W, W + N); int i; for (i = 0; i < N; i++) { L -= W[i]; if (L < 0) break; } printf("%d\n", i); return 0; }