zoukankan      html  css  js  c++  java
  • Codeforces 1065C Make It Equal (差分+贪心)

    题意:n个塔,第i个塔由$h_i$个cube组成,每次可以切去某高度h以上的最多k个cube,问你最少切多少次,可以让所有塔高度相等

    k>=n, n<=2e5

    思路:差分统计每个高度i有的方块数nh[i],然后从高到低贪心的切就行了

    代码:

    #include<iostream>
    #include<cstdio>
    #include<algorithm>
    #include<cmath>
    #include<cstring>
    #include<string>
    //#include<stack>
    #include<queue>
    #include<deque>
    #include<set>
    #include<vector>
    #include<map>
    #include<functional>
        
    #define fst first
    #define sc second
    #define pb push_back
    #define mem(a,b) memset(a,b,sizeof(a))
    #define lson l,mid,root<<1
    #define rson mid+1,r,root<<1|1
    #define lc root<<1
    #define rc root<<1|1
    #define lowbit(x) ((x)&(-x)) 
    
    using namespace std;
    
    typedef double db;
    typedef long double ldb;
    typedef long long ll;
    typedef unsigned long long ull;
    typedef pair<int,int> PI;
    typedef pair<ll,ll> PLL;
    
    const db eps = 1e-6;
    const int mod = 100003;
    const int maxn = 2e5+100;
    const int maxm = 2e5+100;
    const ll inf = 0x3f3f3f3f3f3f3f3f;
    const db pi = acos(-1.0);
    
    int nh[maxn];
    int main() {
        int n;ll m;
        scanf("%d %lld", &n, &m);
        int vol = 0;
        for(int i = 1; i <= n; i++){
            int c;
            scanf("%d", &c);
            nh[0]++;nh[c+1]--;
            
        }
        for(int i = 1; i <= maxn; i++){
            nh[i]+=nh[i-1];
        }
        int tmp = 0;
        int ans = 0;
        for(int i = maxn; i >= 0; i--){
            if(nh[i]==n)break;
            if(tmp+nh[i]>m){
                tmp=nh[i];
                ans++;
            }
            else tmp+=nh[i];
        }
        if(tmp>0)ans++;
        printf("%d", ans);
        return 0;
    }
  • 相关阅读:
    设计模式总结
    JWT、OAUTH2与SSO资料补充
    dajie项目的坑
    fw-cloud-framework项目配置、启动问题
    Shiro源码分析
    (转)JPA & Restful
    Spring Boot以War包启动
    (转)Spring & SpringMVC学习
    MySQL的数据类型(二)
    MySQL的数据类型(一)
  • 原文地址:https://www.cnblogs.com/wrjlinkkkkkk/p/9780373.html
Copyright © 2011-2022 走看看