zoukankan      html  css  js  c++  java
  • 118 ZOJ Monthly, July 2012

    http://acm.zju.edu.cn/onlinejudge/showContestProblems.do?contestId=339

    都是赛后做的。。。弱爆了

    A题是找由2和5组成的数字的个数

    直接打个表就行了

    只是比赛的时候不知道怎么打表啊。。

    View Code
    #include<cstdio>
    #include<cstring>
    #include<algorithm>
    using namespace std;
    
    int a[1000];
    #define ll long long
    const int inf = ~0U>>1;
    int cnt = 0;
    bool judge(ll n){
        int t = 0;
        ll tmp = n;
        while(tmp){
            t++;
            tmp/=10;
        }
        ll r = 1;
        while(t--)r *= 10;
        if(r % n == 0)return true;
        else return false;
    }
    void init(){
        ll p = 1, q = 1;
        for(int i = 0; i < 31;i ++)
        {
            q = 1;
            for(int j = 0; j < 25; j ++)
            {
                if(q > inf)break;
                if(p * q < inf && judge(p * q))
                a[cnt++] = p * q;
                q *= 5;
            }
            p *= 2;
            if(p > inf)
            break;
        }
    }
    int main()
    {
        int m, n;
        init();
        while(~scanf("%d%d", &m, &n)){
            int ans = 0;
            for(int i = 0; i < cnt; i ++){
                if(m <= a[i] && n >= a[i]) ans ++;
            }
            printf("%d\n", ans);
        }
        return 0;
    }

    B题更是不会

    一直以为排序后就选取第一个就是了

    哪知道应该是所有的都计算选取最小的。。跪了Orz

    当然,这题转换成0-1背包也行,我们当时也这样做了,不过还是做错了

    View Code
    #include<cstdio>
    #include<cstring>
    #include<algorithm>
    using namespace std;
    
    int main()
    {
        int n, l;
        while(~scanf("%d%d", &n, &l))
        {
            int cost, weight;
            int ans = 999999999;
            while(n--){
                scanf("%d%d", &cost, &weight);
                /*
                int len = 0;
                int tmp = 0;
                int cnt = 0;
                while(len < l){
                    tmp ++;
                    len += cnt * weight;
                    if(tmp % cost == 0)
                    cnt ++;
                }
                ans = min(ans, tmp);
                */
                int sum = 0;
                for(int i = cost; i < 300; i ++)
                {
                    sum += weight * ((i-1)/cost);
                    if(sum >=l){
                        ans = min(ans, i);
                        break;
                    }
                }
            }
            printf("%d\n", ans);
        }
        return 0;
    }

    J题更是奇葩了,吐嘈不能啊。。。

    数据里应该是好多输出m的,不然为什么少一句if(ans == m)return;就TLE呢 ?

    真心跪到惨。。。

    代码里第一种方法是参考蛋蛋哥的

    搜索到第k个的时候,如果sum加上剩下的和不超过m就直接return了,好想法啊,记住了

    第二种是看大神的博客的

    第三种是我自己的

    怎么写怎么弱,还过不了

    最后几乎都一样了还是过不了

    不想再改了

    View Code
    #include<cstdio>
    #include<cstring>
    #include<algorithm>
    using namespace std;
    
    int a[40];
    int b[40];
    int ans;
    int n, m;
    /*
    void dfs(int k, int sum)
    {
        if(ans == m)return;
        if(k == 0){
            ans = max(sum, ans);
            return;
        }
        if(a[k] + sum <= m)
        {
            if(b[k] + sum <= m)
            {
                ans = max(ans, b[k] + sum);
                return;
            }else{
                ans = max(ans, sum + a[k]);
                dfs(k-1, sum);
                dfs(k-1, sum + a[k]);
            }
        }else{
            ans = max(ans, sum);
            dfs(k-1, sum);
        }
    }
    
    int main(){
        while(~scanf("%d%d", &n, &m))
        {
            for(int i = 1; i <= n; i ++)  scanf("%d", a + i);
            sort(a+1, a +1+ n);
            //for(int i = 1; i <= n;i ++)printf("%d\n", a[i]);
            int count = 1;
            for(int i = 1; i <= n; i ++) if(a[i] <= m) a[count++] = a[i];
            n = count-1;
            //printf("%d\n", n);
            //for(int i = 1; i <= n;i ++)printf("%d\n", a[i]);
            b[1] = a[1];
            for(int i = 2; i <= n; i ++)  b[i] = a[i] + b[i-1];
            //for(int i = 1; i <= n;i ++)printf("%d\n", b[i]);
            ans = 0;
            dfs(n, 0);
            printf("%d\n", ans);
        }
        return 0;
    }
    */
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    void dfs(int id, int sum)
    {
        if(ans == m)return;//为什么少这一句会T  ?
        if(sum > ans ) ans = sum;
        for(int i = id; i < n; i ++)
        {
            if(sum + a[i] <= m)
            dfs(i+1, sum + a[i]);
        }
    }
    int main()
    {
        while(~scanf("%d%d", &n, &m))
        {
            int s = 0;
            for(int i = 0; i < n; i ++)
            {
                scanf("%d", a + i);
                s += a[i];
            }
            if(s <= m)
            {
                printf("%d\n", s);
                continue;
            }
            //memset(vis, 0, sizeof(vis));
            sort(a, a + n);
            ans = -1;
            dfs(0,0);
            if(ans == -1)
            puts("0");
            else
            printf("%d\n", ans);
        }
        return 0;
    }
    
    
    
    
    /*
    
    wrong answer
    int vis[40];
    void dfs(int sum)
    {
        if(ans == m)return;
        if(sum > ans) ans = sum;
        for(int i = 0; i < n; i ++)
        {
            if(vis[i] == 1)continue;
            if(vis[i] == 0)
            {
                vis[i] = 1;
                //sum += a[i];
                if(sum + a[i] <= m)
                //printf("%d\n", sum);
                dfs(sum + a[i]);
                //sum -= a[i];
               // vis[i] = 0;
            }
        }
    }
    int main()
    {
        while(~scanf("%d%d", &n, &m))
        {
            int s = 0;
            for(int i = 0; i < n; i ++)
            {
                scanf("%d", a + i);
                s += a[i];
            }
            if(s <= m)
            {
                printf("%d\n", s);
                continue;
            }
            sort(a, a + n);
            memset(vis, 0, sizeof(vis));
            ans = -1;
            dfs(0);
            if(ans == -1)
            puts("0");
            else
            printf("%d\n", ans);
        }
        return 0;
    }
    */

    本来还想总结一下自己的模板的,看来是没有时间了

    加油吧!

  • 相关阅读:
    红黑树-插入篇
    并查集
    Rabin-Karp【转载】
    KMP
    怎样花两月时间去应聘互联网公司 [转载]
    c++ 智能指针【转载】
    java序列化
    Web页面导出Excel表格
    基于jquery-UI的日期选择器
    Doc命令
  • 原文地址:https://www.cnblogs.com/louzhang/p/2614459.html
Copyright © 2011-2022 走看看