Problem - D2 - Codeforces

Problem - D2 - Codeforces

先讲解D1

当目前剩下的数字的数目为p的时候 一次操作就会减少p/k个元素 因为操作次数少 我们可以直接进行计算 我们可以用二分 枚举第k个数字 判断是否合法 如果x次操作后剩余的数目大于等于k就合法 知道找到等于k的位置:

代码如下:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
#define int long long
void solve(){
    int x,y,k;
    cin>>x>>y>>k;
    int l=1,r=1e12+1;
    while(l<r){
        int mid=(l+r)>>1;
        int tmp=mid;
        for(int i=1;i<=x;i++){
            tmp-=tmp/y;
        }
        if(tmp>=k){
            r=mid;
        }else l=mid+1;
    }
    if(r==1e12+1){
        cout<<-1<<'\n';
        return ;
    }else {
        cout<<r<<'\n';
    }
}
signed main() {
    ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    int t;
    cin>>t;
    while(t--)solve();    
    return 0;
}

D2

由于这次x的范围很大 所以我们无法进行x次模拟计算

但是我们可以根据操作后的数字反向推导操作前的数字

p'=p-p/y 我们可以直观的想象一下: p个数字 分为y块完整块 可以分p/y块 进行一次操作后 每一块都少了一块 也就是如果分为y-1块 不计算剩余的部分的话 块数不变 剩余部分如果刚好相等 可以-1 也就是(p'-1)/(y-1)=p/y

那么有p=p'+(p'-1)/(y-1)

多次操作中(p-1)/(y-1)可能不变 可以批量操作

令c=(k-1)/(y-1) 多次操作中c不变 我们计算c=c+1时的区间左端点 也就是(c+1)*(y-1)+1

cnt=(fk - k + c - 1) / c(向上取整);

每次批量操作cnt次即可

代码实现如下:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
#define int long long
const int INF=1e12;
void solve(){
    int x,y,k;
    cin>>x>>y>>k;
    if(y==1){
        cout<<-1<<'\n';
        return;
    }
    for(int i=0;i<x;){
        int cur=(k-1)/(y-1);    
        if(cur==0){
            break;
        }
        int nxt=(cur+1)*(y-1)+1;
        int cnt=(nxt-k+cur-1)/cur;
        cnt=min(x-i,cnt);
        k+=cnt*cur;
        if(k>INF){
            cout<<-1<<'\n';
            return ;
        }
        i+=cnt;
    }
    cout<<k<<'\n';
}
signed main() {
    ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    int t;
    cin>>t;
    while(t--)solve();    
    return 0;
}
相关推荐
kisshyshy6 小时前
从递归到迭代,一文吃透二叉树的核心知识与 JavaScript 实现
javascript·算法·代码规范
To_OC17 小时前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
用户938515635071 天前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC1 天前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥1 天前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
地平线开发者1 天前
Transformer模型部署之性能优化指南
算法
地平线开发者1 天前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
半个落月1 天前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小月土星1 天前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试