zoukankan      html  css  js  c++  java
  • Alyona and copybooks

    Alyona and copybooks
    time limit per test
    1 second
    memory limit per test
    256 megabytes
    input
    standard input
    output
    standard output

    Little girl Alyona is in a shop to buy some copybooks for school. She study four subjects so she wants to have equal number of copybooks for each of the subjects. There are three types of copybook's packs in the shop: it is possible to buy one copybook for arubles, a pack of two copybooks for b rubles, and a pack of three copybooks for c rubles. Alyona already has n copybooks.

    What is the minimum amount of rubles she should pay to buy such number of copybooks k that n + k is divisible by 4? There are infinitely many packs of any type in the shop. Alyona can buy packs of different type in the same purchase.

    Input

    The only line contains 4 integers nabc (1 ≤ n, a, b, c ≤ 109).

    Output

    Print the minimum amount of rubles she should pay to buy such number of copybooks k that n + k is divisible by 4.

    Examples
    input
    1 1 3 4
    output
    3
    input
    6 2 1 1
    output
    1
    input
    4 4 4 4
    output
    0
    input
    999999999 1000000000 1000000000 1000000000
    output
    1000000000
    Note

    In the first example Alyona can buy 3 packs of 1 copybook for 3a = 3 rubles in total. After that she will have 4 copybooks which she can split between the subjects equally.

    In the second example Alyuna can buy a pack of 2 copybooks for b = 1 ruble. She will have 8 copybooks in total.

    In the third example Alyona can split the copybooks she already has between the 4 subject equally, so she doesn't need to buy anything.

    In the fourth example Alyona should buy one pack of one copybook.

    分析:需要仔细考虑所有情况;

       n=4k,ans=0;

       n=4k+1,ans=min({a,b+c,c*3});

         n=4k+2,ans=min({a*2,b,c*2});

       n=4k+3,ans=min({a*3,b+a,c});

    代码:

    #include <iostream>
    #include <cstdio>
    #include <cstdlib>
    #include <cmath>
    #include <algorithm>
    #include <climits>
    #include <cstring>
    #include <string>
    #include <set>
    #include <map>
    #include <unordered_map>
    #include <queue>
    #include <stack>
    #include <vector>
    #include <list>
    #define rep(i,m,n) for(i=m;i<=n;i++)
    #define rsp(it,s) for(set<int>::iterator it=s.begin();it!=s.end();it++)
    #define mod 1000000007
    #define inf 0x3f3f3f3f
    #define vi vector<int>
    #define pb push_back
    #define mp make_pair
    #define fi first
    #define se second
    #define ll long long
    #define pi acos(-1.0)
    #define pii pair<int,int>
    #define Lson L, mid, ls[rt]
    #define Rson mid+1, R, rs[rt]
    #define sys system("pause")
    #define intxt freopen("in.txt","r",stdin)
    const int maxn=1e5+10;
    using namespace std;
    int gcd(int p,int q){return q==0?p:gcd(q,p%q);}
    ll qpow(ll p,ll q){ll f=1;while(q){if(q&1)f=f*p;p=p*p;q>>=1;}return f;}
    inline ll read()
    {
        ll x=0;int f=1;char ch=getchar();
        while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
        while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
        return x*f;
    }
    int m,k,t;
    ll n,a,b,c;
    int main()
    {
        int i,j;
        scanf("%lld%lld%lld%lld",&n,&a,&b,&c);
        if(n%4==0)puts("0");
        else
        {
            int p=4-n%4;
            if(p==1)printf("%lld
    ",min({a,b+c,c*3}));
            else if(p==2)printf("%lld
    ",min({a*2,b,c*2}));
            else printf("%lld
    ",min({a*3,b+a,c}));
        }
        //system("Pause");
        return 0;
    }
  • 相关阅读:
    SD卡 家族的发展
    onenand小结 及 与nor 和nand 的区别
    PHP程序开发范例学习之表单――获取文本框的值
    Smarty 模板初体验
    symfony object route class: sfDoctrineRoute
    数据结构&算法(PHP描述) 简单选择排序 simple selection sort
    FLEAPHP操作两个数据库
    让Nginx支持ThinkPHP的URL重写和PATHINFO
    Apache中限制和允许特定IP访问(转载)
    php记录日志
  • 原文地址:https://www.cnblogs.com/dyzll/p/6102902.html
Copyright © 2011-2022 走看看