ACM-ICPC 2016 上海赛区ECFINAL A,D

题目链接:Number Theory Problem

#include<bits/stdc++.h>

#define ll long long
using namespace std;

int solve(int cas) {
    int n;cin>>n;
    cout<<"Case #"<<cas<<": ";
    cout<<n/3<<endl;

}
int main() {
    int T;
    cin>>T;
    for(int i=1;i<=T;i++)  {
        solve(i);
    }
    return 0;
}

题目链接: Ice Cream Tower

#include<bits/stdc++.h>
 
#define ll unsigned long long
using namespace std;
 
 
const long long maxn = 1e6 + 7;
 
ll a[maxn];
 
long long n, k;
 
 
bool judge(ll x) {
    queue<pair<ll, ll> > que;
    for (ll i = 1; i <= x; i++) que.push({a[i], 1});
    for (ll i = x + 1; i <= n; i++) {
        if (que.empty()) break;
        pair<ll, ll> pii = que.front();
        if (a[i] / 2 >= pii.first) {
            que.pop();
            if (pii.second == k - 1) continue;
            que.push({a[i], pii.second + 1});
        }
    }
    return que.empty();
 
}
 
long long solve(long long cas) {
    cin >> n >> k;
    for (long long i = 1; i <= n; i++) cin >> a[i];
    cout << "Case #" << cas << ": ";
    if (k == 1) {
        cout << n << endl;
        return 0;
    }
    sort(a + 1, a + 1 + n);
    ll l = 0, r = n;
    ll ans = 0;
 
    while (r - l > 1) {
        ll mid = (l + r) / 2;
        if (judge(mid)) {
            l = mid;
        } else r = mid;
    }
    cout << l << endl;
}
 
int main() {
 
    long long T;
    cin >> T;
    for (long long i = 1; i <= T; i++) {
        solve(i);
    }
    return 0;
}

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值