QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#739650 | #9423. Gold Medal | zzisjtu | RE | 1ms | 3548kb | C++23 | 1.5kb | 2024-11-12 22:35:23 | 2024-11-12 22:35:25 |
Judging History
answer
#include <bits/stdc++.h>
#define int long long
#define all(x) x.begin(), x.end()
#define lowbit(i) ((i)&(-i))
#define pii pair<int,int>
#define endl '\n'
#define mk(x,y) make_pair(x,y)
#define popcount(x) __builtin_popcount(x)
#define LF(x) fixed<<setprecision(x)
const double pi = 3.14159265358979323846;
const double eps = 1e-9;
const int inf = 1e9;
const long long INF = 4e18;
const int mod = 1e9+7;
using namespace std;
const int N = 1e5+10;
int k;
struct node {
int x;
bool operator<(const node &a)const {
int tx = x % k, ty = a.x % k;
if (!tx)tx = k;
if (!ty)ty = k;
return tx >= ty;
}
};
void solve() {
int n;
cin >> n >> k;
vector<node>a(n);
// for (auto& i : a)cin >> i;
for(int i = 0; i < n; i++)cin >> a[i].x;
// auto cmp = [&](int x, int y) -> bool {
// int tx = x % k, ty = y % k;
// if (!tx)tx = k;
// if (!ty)ty = k;
// return tx >= ty;
// };
sort(all(a));
int ret = 0;
int m; cin >> m;
for (int i = 0; i < n; i++) {
int t = a[i].x % k;
if (t && m > k - t) {
a[i].x += k - t;
m -= k - t;
}
ret += 0ll + a[i].x / k;
}
ret += 0 + m / k;
cout << ret << endl;
}
signed main() {
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
int T = 1;
cin >> T;
while (T--) {
solve();
}
return 0;
}
詳細信息
Test #1:
score: 100
Accepted
time: 1ms
memory: 3548kb
input:
2 3 10 239 141 526 6 2 1 300 100 1000
output:
91 1400
result:
ok 2 lines
Test #2:
score: -100
Runtime Error
input:
100 39 88 746 86884 628655 868 87506 46761498 3338 91952768 312 9712 5277106 2263554 246545 98849 91459 6 5506 4 17626 5984050 32079 10 7672277 8104250 62 8976 866448 1 4 62240996 93128 181 6 9 5 175665 9 7680943 81 239822 9 200383 53147 17 82509 3 617847780 418677763 5402536 16 38253558 79857 66 60...