結果

問題 No.580 旅館の予約計画
ユーザー ukuku09ukuku09
提出日時 2017-10-10 17:26:03
言語 C++11
(gcc 11.4.0)
結果
TLE  
実行時間 -
コード長 1,101 bytes
コンパイル時間 1,362 ms
コンパイル使用メモリ 167,528 KB
実行使用メモリ 17,104 KB
最終ジャッジ日時 2024-11-21 13:37:53
合計ジャッジ時間 101,516 ms
ジャッジサーバーID
(参考情報)
judge3 / judge4
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
13,644 KB
testcase_01 AC 1 ms
10,020 KB
testcase_02 AC 3 ms
13,640 KB
testcase_03 TLE -
testcase_04 TLE -
testcase_05 TLE -
testcase_06 TLE -
testcase_07 TLE -
testcase_08 TLE -
testcase_09 TLE -
testcase_10 TLE -
testcase_11 TLE -
testcase_12 TLE -
testcase_13 TLE -
testcase_14 TLE -
testcase_15 TLE -
testcase_16 TLE -
testcase_17 TLE -
testcase_18 TLE -
testcase_19 TLE -
testcase_20 TLE -
testcase_21 TLE -
testcase_22 TLE -
testcase_23 TLE -
testcase_24 TLE -
testcase_25 TLE -
testcase_26 TLE -
testcase_27 TLE -
testcase_28 TLE -
testcase_29 TLE -
testcase_30 TLE -
testcase_31 TLE -
testcase_32 TLE -
testcase_33 TLE -
testcase_34 TLE -
testcase_35 TLE -
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:10:8: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   10 |   scanf("%d %d", &n, &m);
      |   ~~~~~^~~~~~~~~~~~~~~~~
main.cpp:14:12: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   14 |       scanf("%d %d:%d", &d, &h, &m);
      |       ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~

ソースコード

diff #

#include <bits/stdc++.h>

using namespace std;

using Pi = pair<int, int>;

int main() {
  int n, m;
  int t[1001][2];
  scanf("%d %d", &n, &m);
  for(int i = 0; i < m; i++) {
    for(int j = 0; j < 2; j++) {
      int d, h, m;
      scanf("%d %d:%d", &d, &h, &m);
      t[i][j] = d*24*60+h*60+m;
    }
  }
  vector<Pi> vec;
  for(int i = 0; i < m; i++) {
    vec.emplace_back(t[i][0], t[i][1]);
  }
  sort(vec.begin(), vec.end());
  int room[101] = {};
  vector<int> who;
  int ans = 0;
  auto print = [&](int ts) {
    printf("%d %d:%d\n", ts/(24*60), ts%(24*60)/60, ts%(24*60)%60);
  };
  function<void(int,int)> dfs = [&](int idx, int cnt) {
    if(idx == m) {
      ans = max(ans, cnt);
      /*
      if(cnt == 11) {
	for(int s : who) {
	  print(s);
	}
	exit(0);
      }
      */
      return;
    }
    dfs(idx+1, cnt);
    for(int i = 0; i < n; i++) {
      if(room[i] < vec[idx].first) {
	int tmp = room[i];
	room[i] = vec[idx].second;
	who.push_back(vec[idx].second);
	dfs(idx+1, cnt+1);
	who.pop_back();
	room[i] = tmp;
      }
    }
  };
  dfs(0, 0);
  printf("%d\n", ans);

  return 0;
}
0