zoukankan      html  css  js  c++  java
  • codeforces 189A

    原题连接:

      http://codeforces.com/problemset/problem/189/A

    题意:

      给你一个长度为n的布条,按给定的a,b,c三种长度切布条(得到的必须满足a,b,c三种之一)能得到的最多布条数;

    思路:

      (1)正常思考:那就是a,b,c之中先按最短的来切,然后第二短的,最后按最长的

      (2)但会有一些特殊的数据,如:53 10 11 23;(1)的想法得到的是4(即3给10,1个23),但正确答案是5(即3个11,2个10);

      (3)根据(2)的特殊情况,那么就在添加一种切的方法:a,b,c之中先按第二短的来切,然后最短的,最后按最长的;最后取一下最大值即可;

      ps:还有一种用动态规划的方式,怎奈本人水平过低,不会!!!!!!!!

      1 #include<cstdio>
      2 #include<string>
      3 #include<iostream>
      4 #include<algorithm>
      5 
      6 using namespace std;
      7 
      8 int main()
      9 {
     10     int n,a[3],d1=1,d2=1;
     11     int la,lb,lc,i,j,k,x1,x2,x3,flag=0;
     12     cin>>n>>a[0]>>a[1]>>a[2];
     13     sort(a,a+3);
     14     la=n/a[0];
     15     lb=n/a[1];
     16     lc=n/a[2];
     17     for(i=la;i>=0;i--)
     18     {
     19     //    printf("i=%d
    ",i);
     20         x1=n-i*a[0];
     21     //    printf("!x1=%d
    ",x1);
     22         if(x1==0)
     23         {
     24             d1=i;
     25             flag=1;
     26             break;
     27         }
     28         for(j=0;j<=lb;j++)
     29         {
     30         //    printf("j=%d
    ",j);
     31             x2=x1-j*a[1];
     32         //    printf("@x2=%d
    ",x2);
     33             if(x2==0)
     34             {
     35                 d1=i+j;
     36                 flag=1;
     37                 break;
     38             }
     39             if(x2<0)
     40                 break;
     41             for(k=0;k<=lc;k++)
     42             {
     43             //    printf("k=%d
    ",k);
     44                 x3=x2-k*a[2];
     45             //    printf("#x3=%d
    ",x3);
     46                 if(x3==0)
     47                 {
     48                     d1=i+j+k;
     49                     flag=1;
     50                     break;
     51                 }
     52                 if(x3<0)
     53                     break;
     54             }
     55             if(flag)
     56                 break;
     57         }
     58         if(flag)
     59             break;
     60     }
     61     flag=0;
     62     for(i=lb;i>=0;i--)
     63     {
     64     //    printf("i=%d
    ",i);
     65         x1=n-i*a[1];
     66     //    printf("!x1=%d
    ",x1);
     67         if(x1==0)
     68         {
     69             d2=i;
     70             flag=1;
     71             break;
     72         }
     73         for(j=0;j<=la;j++)
     74         {
     75     //        printf("j=%d
    ",j);
     76             x2=x1-j*a[0];
     77     //        printf("@x2=%d
    ",x2);
     78             if(x2==0)
     79             {
     80                 d2=i+j;
     81                 flag=1;
     82                 break;
     83             }
     84             if(x2<0)
     85                 break;
     86             for(k=0;k<=lc;k++)
     87             {
     88     //            printf("k=%d
    ",k);
     89                 x3=x2-k*a[2];
     90     //            printf("#x3=%d
    ",x3);
     91                 if(x3==0)
     92                 {
     93                     d2=i+j+k;
     94                     flag=1;
     95                     break;
     96                 }
     97                 if(x3<0)
     98                     break;
     99             }
    100             if(flag)
    101                 break;
    102         }
    103         if(flag)
    104             break;
    105     }
    106 //    cout<<"d1="<<d1<<" d2="<<d2<<endl;
    107     if(d1<d2)
    108         d1=d2;
    109     cout<<d1<<endl;
    110     
    111     return 0;
    112 }

    欢迎大家评论!!!

  • 相关阅读:
    JSP实现页面自动跳转
    marquee属性的使用说明
    jsp 按钮 超链接 直接跳转至另一页面
    生成验证码图片代码
    js 通过判断月数填充日数下拉框
    邮箱正则验证
    jsp 验证用正则表达式
    onselectstart 与 -moz-user-select
    onselectstart 、onselect区别
    NSOperation基本操作
  • 原文地址:https://www.cnblogs.com/x-x-y/p/6900465.html
Copyright © 2011-2022 走看看