QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#488042 | #140. Palembang Bridges | Dimash | 0 | 0ms | 3844kb | C++14 | 1.5kb | 2024-07-23 15:33:39 | 2024-07-23 15:33:39 |
answer
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 1e6 + 21, MOD = (int)1e9+7;
int n,k;
ll res = 0;
array<int,2> a[N];
ll val[N];
ll solve(){
vector<pair<int,int>> sc;
for(int i = 1;i <= n;i++){
sc.push_back({a[i][0],0});
sc.push_back({a[i][1],1});
}
sort(sc.begin(),sc.end());
ll sum = 0,col = 0;
for(int i = 0;i < (int)sc.size();i++){
val[i] = (sc[i].first * 1ll * col) - sum;
if(sc[i].second == 1){
col++;
sum += sc[i].first;
}
}
col = sum =0 ;
ll res = 1e18;
for(int i = (int)sc.size() - 1;i >= 0;i--){
val[i] += sum - (sc[i].first * 1ll * col);
if(sc[i].second == 0){
col++;
sum += sc[i].first;
}
res = min(res,val[i] * 2);
}
return res;
}
void test() {
cin >> k >> n;
int _i = 0;
for(int i = 1;i <= n;i++) {
char x,y;
int l,r;
cin >> x >> l >> y >> r;
if(l > r){
swap(l,r);
swap(x,y);
}
res += (r - l);
if(x == y){
continue;
}
res++;
a[++_i] = {l,r};
}
n = _i;
if(k == 1){
cout << res + solve();
return;
}
}
int main() {
ios_base::sync_with_stdio(false);cin.tie(0);
int t = 1;
// cin >> t;
while(t--) {
test();
}
}
详细
Subtask #1:
score: 0
Wrong Answer
Test #1:
score: 0
Wrong Answer
time: 0ms
memory: 3576kb
input:
1 1 B 426311872 B 741424667
output:
1000000000315112795
result:
wrong answer 1st lines differ - expected: '315112795', found: '1000000000315112795'
Subtask #2:
score: 0
Skipped
Dependency #1:
0%
Subtask #3:
score: 0
Wrong Answer
Test #22:
score: 0
Wrong Answer
time: 0ms
memory: 3844kb
input:
2 1 B 822190955 B 309099167
output:
result:
wrong answer 1st lines differ - expected: '513091788', found: ''
Subtask #4:
score: 0
Skipped
Dependency #3:
0%
Subtask #5:
score: 0
Skipped
Dependency #4:
0%