Submission #73652842
Source Code Expand
#include <bits/stdc++.h>
#include <atcoder/all>
#define rep(i,a,b) for(int i = a;i < b; i++)
#define rrep(i,a,b) for(int i = a;i >= b; i--)
#define all(x) (x).begin(),(x).end()
using namespace std;
using namespace atcoder;
using ll = long long;
using vc = vector<int>;
using vb = vector<bool>;
using vvc = vector<vector<int>>;
using vvb = vector<vector<bool>>;
using mint = modint1000000007;
template<class T> inline bool chmax(T& a, T b) { if (a < b) { a = b; return true; } return false; }
template<class T> inline bool chmin(T& a, T b) { if (a > b) { a = b; return true; } return false; }
const long long INF = 1LL << 60;
const int IINF = 1 << 30;
const int IMAX = INT_MAX;
const long long MOD = 100000;
//1000000007
int dx[] = {-1, 1, 0, 0,1,-1,1,-1};
int dy[] = {0, 0, -1, 1,1,1,-1,-1};
using S = long long;
using F = long long;
/*
struct S = {
// なんか
};
*/
S op(S a, S b){ return max(a,b); }
S e(){ return INF; }
S mapping(F f, S x){ return f+x; }
F composition(F f, F g){ return f+g; }
F id(){ return 0; }
// オーバーフロー注意!
// 一つの解法に頼らずいろんな可能性を考える!
// わからなくなったらとりあえず数式にしてみる!
// 迷ったらとりあえず全探索!
// dpの遷移は求めたいものから逆算する
// 関係性がありそうだったらグラフや平面において解いてみる(平面走査なども)
// 規則性を見つける。ある値を決めてみて解けるかどうか。
// 連続する区間は累積和、尺取り、二分探索、区間dpなどなど
// クエリの問題は愚直にやったらTLEするやつを工夫して高速化
// 変数名は似たような奴にしない
// いらない情報は持たない
void solve(){
int n;
cin >> n;
map<int,vector<ll>> mp;
for(int i = 0; i < n; ++i){
int p,q;
cin >> p >> q;
mp[p].push_back(q);
}
ll ans = 0;
for(auto [i,a] : mp){
sort(all(a));
int idx = 0;
ll de = 0;
while(idx<a.size()){
ll cnt = 1;
while(idx+cnt<a.size()&&a[idx]==a[idx+cnt]){
++cnt;
}
ans += cnt*((ll)a.size()-de-cnt);
de+=cnt;
idx+=cnt;
}
}
cout << ans << "\n";
return;
}
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
//freopen("input.txt", "r", stdin);
int t = 1;
//cin >> t;
while(t--){
solve();
}
return 0;
}
Submission Info
| Submission Time | |
|---|---|
| Task | C - Matchup Card Combinations |
| User | toshx |
| Language | C++23 (GCC 15.2.0) |
| Score | 333 |
| Code Size | 2491 Byte |
| Status | AC |
| Exec Time | 94 ms |
| Memory | 14516 KiB |
Compile Error
./Main.cpp: In function 'void solve()':
./Main.cpp:70:14: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<long long int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
70 | while(idx<a.size()){
| ~~~^~~~~~~~~
./Main.cpp:72:20: warning: comparison of integer expressions of different signedness: 'll' {aka 'long long int'} and 'std::vector<long long int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
72 | while(idx+cnt<a.size()&&a[idx]==a[idx+cnt]){
| ~~~~~~~^~~~~~~~~
Judge Result
| Set Name | Sample | All | ||||
|---|---|---|---|---|---|---|
| Score / Max Score | 0 / 0 | 333 / 333 | ||||
| Status |
|
|
| Set Name | Test Cases |
|---|---|
| Sample | sample01.txt, sample02.txt, sample03.txt |
| All | sample01.txt, sample02.txt, sample03.txt, in01.txt, in02.txt, in03.txt, in04.txt, in05.txt, in06.txt, in07.txt, in08.txt, in09.txt, in10.txt, in11.txt, in12.txt, in13.txt, in14.txt, in15.txt, in16.txt, in17.txt, in18.txt, in19.txt, in20.txt, in21.txt, in22.txt, in23.txt, in24.txt, in25.txt, in26.txt, in27.txt, in28.txt, in29.txt, in30.txt, in31.txt, in32.txt, in33.txt, in34.txt, in35.txt, in36.txt, in37.txt, in38.txt, in39.txt, in40.txt, in41.txt, in42.txt, in43.txt, in44.txt, in45.txt, in46.txt, in47.txt, in48.txt, in49.txt, in50.txt, in51.txt, in52.txt, in53.txt, in54.txt, in55.txt, in56.txt, in57.txt, in58.txt, in59.txt, in60.txt |
| Case Name | Status | Exec Time | Memory |
|---|---|---|---|
| in01.txt | AC | 1 ms | 3396 KiB |
| in02.txt | AC | 1 ms | 3420 KiB |
| in03.txt | AC | 1 ms | 3436 KiB |
| in04.txt | AC | 1 ms | 3356 KiB |
| in05.txt | AC | 1 ms | 3424 KiB |
| in06.txt | AC | 14 ms | 6552 KiB |
| in07.txt | AC | 90 ms | 13764 KiB |
| in08.txt | AC | 18 ms | 5220 KiB |
| in09.txt | AC | 92 ms | 14436 KiB |
| in10.txt | AC | 27 ms | 5408 KiB |
| in11.txt | AC | 30 ms | 5440 KiB |
| in12.txt | AC | 27 ms | 5072 KiB |
| in13.txt | AC | 86 ms | 13868 KiB |
| in14.txt | AC | 13 ms | 6412 KiB |
| in15.txt | AC | 14 ms | 5280 KiB |
| in16.txt | AC | 22 ms | 5412 KiB |
| in17.txt | AC | 28 ms | 5504 KiB |
| in18.txt | AC | 13 ms | 6480 KiB |
| in19.txt | AC | 17 ms | 6400 KiB |
| in20.txt | AC | 26 ms | 5720 KiB |
| in21.txt | AC | 31 ms | 5740 KiB |
| in22.txt | AC | 14 ms | 6400 KiB |
| in23.txt | AC | 1 ms | 3508 KiB |
| in24.txt | AC | 1 ms | 3464 KiB |
| in25.txt | AC | 1 ms | 3396 KiB |
| in26.txt | AC | 1 ms | 3420 KiB |
| in27.txt | AC | 1 ms | 3396 KiB |
| in28.txt | AC | 31 ms | 5684 KiB |
| in29.txt | AC | 1 ms | 3436 KiB |
| in30.txt | AC | 1 ms | 3420 KiB |
| in31.txt | AC | 1 ms | 3464 KiB |
| in32.txt | AC | 1 ms | 3556 KiB |
| in33.txt | AC | 1 ms | 3556 KiB |
| in34.txt | AC | 1 ms | 3584 KiB |
| in35.txt | AC | 15 ms | 5660 KiB |
| in36.txt | AC | 14 ms | 6400 KiB |
| in37.txt | AC | 15 ms | 6472 KiB |
| in38.txt | AC | 47 ms | 14516 KiB |
| in39.txt | AC | 16 ms | 6432 KiB |
| in40.txt | AC | 74 ms | 10588 KiB |
| in41.txt | AC | 29 ms | 5316 KiB |
| in42.txt | AC | 27 ms | 5440 KiB |
| in43.txt | AC | 24 ms | 5496 KiB |
| in44.txt | AC | 20 ms | 5204 KiB |
| in45.txt | AC | 42 ms | 14508 KiB |
| in46.txt | AC | 94 ms | 14508 KiB |
| in47.txt | AC | 1 ms | 3356 KiB |
| in48.txt | AC | 1 ms | 3384 KiB |
| in49.txt | AC | 1 ms | 3436 KiB |
| in50.txt | AC | 1 ms | 3308 KiB |
| in51.txt | AC | 1 ms | 3508 KiB |
| in52.txt | AC | 1 ms | 3420 KiB |
| in53.txt | AC | 1 ms | 3420 KiB |
| in54.txt | AC | 1 ms | 3428 KiB |
| in55.txt | AC | 1 ms | 3404 KiB |
| in56.txt | AC | 1 ms | 3368 KiB |
| in57.txt | AC | 1 ms | 3348 KiB |
| in58.txt | AC | 1 ms | 3308 KiB |
| in59.txt | AC | 1 ms | 3412 KiB |
| in60.txt | AC | 14 ms | 5304 KiB |
| sample01.txt | AC | 1 ms | 3308 KiB |
| sample02.txt | AC | 1 ms | 3436 KiB |
| sample03.txt | AC | 1 ms | 3348 KiB |