• HDU


    非常可乐

    Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
    Total Submission(s): 16071    Accepted Submission(s): 6488


    Problem Description
    大家一定觉的运动以后喝可乐是一件很惬意的事情,但是seeyou却不这么认为。因为每次当seeyou买了可乐以后,阿牛就要求和seeyou一起分享这一瓶可乐,而且一定要喝的和seeyou一样多。但seeyou的手中只有两个杯子,它们的容量分别是N 毫升和M 毫升 可乐的体积为S (S<101)毫升 (正好装满一瓶) ,它们三个之间可以相互倒可乐 (都是没有刻度的,且 S==N+M,101>S>0,N>0,M>0) 。聪明的ACMER你们说他们能平分吗?如果能请输出倒可乐的最少的次数,如果不能输出"NO"。
     
    Input
    三个整数 : S 可乐的体积 , N 和 M是两个杯子的容量,以"0 0 0"结束。
     
    Output
    如果能平分的话请输出最少要倒的次数,否则输出"NO"。
     
    Sample Input
    7 4 3 4 1 3 0 0 0
     
    Sample Output
    NO 3
     
    Author
    seeyou
     
    Source
     
    Recommend
    LL
     
    开三维数组存取三杯水含量,分六种情况尝试。
     
    #include<stdio.h>
    #include<string.h>
    #include<queue>
    using namespace std;
    
    struct Node{
        int x,y,z,s;
    }node;
    int bo[105][105][105];
    
    int main()
    {
        int a,b,c,i;
        while(scanf("%d%d%d",&a,&b,&c)&&!(a==0&&b==0&&c==0)){
            if(a&1){
                printf("NO
    ");
                continue;
            }
            queue<Node> q;
            memset(bo,0,sizeof(bo));
            bo[a][0][0]=1;
            node.x=a;
            node.y=0;
            node.z=0;
            node.s=0;
            q.push(node);
            int f=0;
            while(q.size()){
                for(i=1;i<=6;i++){
                    int tx=q.front().x;
                    int ty=q.front().y;
                    int tz=q.front().z;
                    int ttx,tty,ttz;
                    if(i==1){
                        ttx=tx>b-ty?tx-b+ty:0;
                        tty=tx>b-ty?b:ty+tx;
                        ttz=tz;
                    }
                    if(i==2){
                        ttx=tx>c-tz?tx-c+tz:0;
                        tty=ty;
                        ttz=tx>c-tz?c:tz+tx;
                    }
                    if(i==3){
                        ttx=ty>a-tx?a:tx+ty;
                        tty=ty>a-tx?ty-a+tx:0;
                        ttz=tz;
                    }
                    if(i==4){
                        ttx=tx;
                        tty=ty>c-tz?ty-c+tz:0;
                        ttz=ty>c-tz?c:tz+ty;
                    }
                    if(i==5){
                        ttx=tz>a-tx?a:tx+tz;
                        tty=ty;
                        ttz=tz>a-tx?tz-a+tx:0;
                    }
                    if(i==6){
                        ttx=tx;
                        tty=tz>b-ty?b:ty+tz;
                        ttz=tz>b-ty?tz-b+ty:0;
                    }
                    if(ttx==a/2&&(tty==a/2||ttz==a/2)){
                        f=q.front().s+1;
                        break;
                    }
                    if(bo[ttx][tty][ttz]==0){
                        bo[ttx][tty][ttz]=1;
                        node.x=ttx;
                        node.y=tty;
                        node.z=ttz;
                        node.s=q.front().s+1;
                        q.push(node);
                    }
                }
                if(f!=0) break;
                q.pop();
            }
            if(f==0) printf("NO
    ");
            else printf("%d
    ",f);
        }
        return 0;
    }
  • 相关阅读:
    Python TIPS上一道关于人民币金额小写转大写的题
    C Primer Plus--C预处理器和C库(1)
    C Primer Plus--位操作
    C Primer Plus--结构和其他数据类型(2)
    计算机缓存方式对于程序运行的影响
    7. 整数反转
    服务器初始化安装docker、docker-compose
    nacos爬坑史-1
    Kafka 报错: Error Uncaught exception in scheduled task 'flush-log'
    CentOS中docker部署的项目CPU占用率持续100%以上
  • 原文地址:https://www.cnblogs.com/yzm10/p/7252561.html
Copyright © 2020-2023  润新知