zoukankan      html  css  js  c++  java
  • 【codeforces 789A】Anastasia and pebbles

    【题目链接】:http://codeforces.com/contest/789/problem/A

    【题意】

    有n种物品,每种物品有wi个;
    你有两个口袋,每个口袋最多装k个物品;
    且口袋里面只能装同一种物品;
    问你最多需要多少天能拿走所有的物品;
    这里你每天只拿一次,也就是说你每天只能使用你的两个口袋一次;
    下一天又能使用了;

    【题解】

    贪心即可;
    对于每一种物品,如果需要用两个口袋装,就用两个口袋去装;
    如果只要一个口袋装,就另外一个口袋装下一种物品

    【完整代码】

    #include <bits/stdc++.h>
    using namespace std;
    #define lson l,m,rt<<1
    #define rson m+1,r,rt<<1|1
    #define LL long long
    #define rep1(i,a,b) for (int i = a;i <= b;i++)
    #define rep2(i,a,b) for (int i = a;i >= b;i--)
    #define mp make_pair
    #define pb push_back
    #define fi first
    #define se second
    #define rei(x) scanf("%d",&x)
    #define rel(x) scanf("%lld",&x)
    #define ref(x) scanf("%lf",&x)
    
    typedef pair<int, int> pii;
    typedef pair<LL, LL> pll;
    
    const int dx[9] = { 0,1,-1,0,0,-1,-1,1,1 };
    const int dy[9] = { 0,0,0,-1,1,-1,1,-1,1 };
    const double pi = acos(-1.0);
    const int N = 1e5+100;
    
    int n, k, a[N],ans=0;
    
    void in()
    {
        rei(n), rei(k);
        rep1(i, 1, n)
            rei(a[i]);
    }
    
    void get_ans()
    {
        rep1(i,1,n)
        if (a[i]>0)
        {
            if (a[i] >= 2 * k)
            {
                if (a[i] % (2 * k) == 0)
                    ans += a[i] / (2 * k);
                else
                    ans += a[i] / (2 * k);
                a[i] %= (2 * k);
            }
    
            if (a[i] == 0) continue;
    
            if (a[i] > k)
            {
                ans++;
                a[i] = 0;
            }
            else
            {
                a[i] = 0;
                a[i + 1] -= min(k, a[i + 1]);
                ans++;
            }
        }
    }
    
    bool cmp1(int a, int b)
    {
        return a > b;
    }
    
    void o()
    {
        printf("%d
    ", ans);
    }
    
    int main()
    {
        //freopen("F:\rush.txt", "r", stdin);
        in();//checked
        get_ans();//checked
        o();//checked
        //printf("
    %.2lf sec 
    ", (double)clock() / CLOCKS_PER_SEC);
        return 0;
    }
  • 相关阅读:
    js:DOM及其操作2
    js:DOM及其操作
    闭包,作用域,作用域链
    面向对象
    关于typeof
    javascript正则表达式&关键词检索
    关于StringAPI
    mybatis Invalid bound statement (not found)
    全国区域数据
    redis 问题整理
  • 原文地址:https://www.cnblogs.com/AWCXV/p/7626516.html
Copyright © 2011-2022 走看看