zoukankan      html  css  js  c++  java
  • 【CODEVS】倒水问题


    题目描述:

    有两个无刻度标志的水壶,分别可装 x 升和 y 升 ( x,y 为整数且均不大于 100 )的水。设另有一水 缸,可用来向水壶灌水或接从水壶中倒出的水, 两水壶间,水也可以相互倾倒。已知 x 升壶为空 壶, y 升壶为空壶。问如何通过倒水或灌水操作, 用最少步数能在x或y升的壶中量出 z ( z ≤ 100 )升的水 来

    输入描述:

    一行,三个数据,分别表示 x,y 和 z;

    输出描述:

    一行,输出最小步数 ,如果无法达到目标,则输出"impossible"

    样例输入:

    3 22 1

    样例输出:

    14


    直接暴力掉。x倒入y中、y倒入z中、x倒空、z倒空、x倒满、y倒满六种大情况。

    #include<cstdio>
    #include<iostream>
    #include<queue>
    using namespace std;
    int x,y,z;
    
    bool book[20000][20000];
    
    struct v
    {
    	int a,b,step;
    	bool operator()()
    	{
    		return a==z || b==z;
    	}
    	v(int c,int d,int e):a(c),b(d),step(e){};
    };
    queue<v> q;
    
    bool bfs()
    {
    	v temp(0,0,0);
    	q.push(temp);
    	while(!q.empty())
    	{
    		int a,b,step;
    		temp=q.front();
    		q.pop();
    		if(temp())
    		{
    			cout<<temp.step;
    			return true;
    		}
    		a=temp.a;
    		b=temp.b;
    		step=temp.step;
    		for(int i=0;i<6;i++)
    		{
    			int q1,q2,q3;
    			if(i==0&&a!=x)q1=x,q2=b,q3=step+1;
    			else if(i==1&&b!=y)q1=a,q2=y,q3=step+1;
    			else if(i==2&&b<y&&a>0){
    				if(b+a>y) q1=a-y+b,q2=y,q3=step+1;
    				else  q1=0,q2=b+a,q3=step+1;
    			}
    			else if(i==3&&a<x&&b>0){
    				if(a+b>x) q1=x,q2=b-x+a,q3=step+1;
    				else	  q1=b+a,q2=0,q3=step+1;
    			}
    			else if(i==4&&a>0) q1=0,q2=b,q3=step+1;
    			else if(i==5&&b>0) q1=a,q2=0,q3=step+1;	
    			if(!book[q1][q2])
    			{
    				q.push(v(q1,q2,q3));
    				book[q1][q2]=true;
    			}
    		}
    	}
    	return false;
    }
    int main()
    {
    	cin>>x>>y>>z;
    	if(!bfs())
    		cout<<"impossible";
    	return 0;
    }




  • 相关阅读:
    第三章 读书笔记
    第一章 读书笔记
    第二章 读书笔记
    第九章
    第十章
    第8章 蜂鸣器
    第7章 led闪烁
    第6章 第一个Linux驱动程序:统计单词个数
    第5章 搭建S3C6410开发板环境
    第3章 Git使用入门
  • 原文地址:https://www.cnblogs.com/huibixiaoxing/p/6537767.html
Copyright © 2011-2022 走看看