結果

問題 No.1722 [Cherry 3rd Tune C] In my way
ユーザー 👑 NachiaNachia
提出日時 2024-04-18 02:49:15
言語 C++17
(gcc 12.3.0 + boost 1.83.0)
結果
AC  
実行時間 3 ms / 2,000 ms
コード長 1,106 bytes
コンパイル時間 1,096 ms
コンパイル使用メモリ 89,332 KB
実行使用メモリ 5,248 KB
最終ジャッジ日時 2024-10-09 20:31:19
合計ジャッジ時間 1,925 ms
ジャッジサーバーID
(参考情報)
judge4 / judge3
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
5,248 KB
testcase_01 AC 2 ms
5,248 KB
testcase_02 AC 2 ms
5,248 KB
testcase_03 AC 3 ms
5,248 KB
testcase_04 AC 3 ms
5,248 KB
testcase_05 AC 2 ms
5,248 KB
testcase_06 AC 2 ms
5,248 KB
testcase_07 AC 2 ms
5,248 KB
testcase_08 AC 2 ms
5,248 KB
testcase_09 AC 2 ms
5,248 KB
testcase_10 AC 2 ms
5,248 KB
testcase_11 AC 3 ms
5,248 KB
testcase_12 AC 2 ms
5,248 KB
testcase_13 AC 2 ms
5,248 KB
testcase_14 AC 2 ms
5,248 KB
testcase_15 AC 2 ms
5,248 KB
testcase_16 AC 2 ms
5,248 KB
testcase_17 AC 3 ms
5,248 KB
testcase_18 AC 2 ms
5,248 KB
testcase_19 AC 2 ms
5,248 KB
testcase_20 AC 2 ms
5,248 KB
testcase_21 AC 2 ms
5,248 KB
testcase_22 AC 2 ms
5,248 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <iostream>
#include <vector>
#include <algorithm>
#include <map>
using namespace std;
using i64 = long long;
using u64 = unsigned long long;
#define rep(i,n) for(int i=0; i<(n); i++)

vector<pair<u64,u64>> factorize(u64 n){
  vector<pair<u64,u64>> res;
  for(u64 i=2; i*i<=n; i++){
    if(n%i) continue;
    res.push_back({i,0});
    while(n%i==0){ n/=i; res.back().second++; }
  }
  if(n!=1) res.push_back({n,1});
  return move(res);
}


int main(){
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
  int num_people; cin >> num_people;
  int num_walls; cin >> num_walls;
  vector<int> pos_people(num_people);
  for(int& a : pos_people) cin >> a;
  vector<int> pos_walls(num_walls);
  for(int& a : pos_walls) cin >> a;

  sort(pos_walls.begin(), pos_walls.end());
  for(int& x : pos_people){
    auto first_hit = lower_bound(pos_walls.begin(), pos_walls.end(), x) - pos_walls.begin();
    if(first_hit == pos_walls.size()){
      cout << "Infinity\n";
    }
    else{
      auto pos_hit = pos_walls[first_hit];
      int ans = pos_hit - x;
      cout << ans << "\n";
    }
  }
  return 0;
}
0