zoukankan      html  css  js  c++  java
  • poj 3414

    题意:给出两个容积分别为 a 和 b 的pot,按照以下三种操作方式,求出能否在一定步数后,使者两个pot的其中一个的水量为c。

          1.FILL(i):将ipot倒满水。

          2.DROP(i):将ipot倒空水。

          3.POUR(i,j): 将ipot的水倒到jpot上,直至要么ipot为空,要么jpot为满。

    典型的最短求解问题 并记录路径
    #include<iostream> #include<queue> using namespace std; bool v[111][111]; struct No { int a,b; int step; int prex,prey; }; struct Node { int step; int prex,prey; char a[15]; }map[111][111]; int a,b,c; void out(int x,int y) { if(map[x][y].prex==-1&&map[x][y].prey==-1) return ; out(map[x][y].prex,map[x][y].prey); cout<<map[x][y].a<<endl; } bool bfs() { queue<No>q; No now,next; now.a=0;now.b=0; now.step=0; now.prex=-1;now.prey=-1; memset(v,false,sizeof(v)); v[0][0]=true; q.push(now); map[0][0].prex=-1;map[0][0].prey=-1; map[0][0].step=0; while(!q.empty()) { now=q.front(); if(now.a==c||now.b==c) { cout<<now.step<<endl; out(now.a,now.b); return true; } q.pop(); //1填满 if(now.a<a&&(!v[a][now.b]||map[a][now.b].step>now.step+1)) { v[a][now.b]=1; next=now; next.a=a; next.step++; next.prex=now.a; next.prey=now.b; char s[]="FILL(1)"; strcpy(map[next.a][next.b].a,s); map[next.a][next.b].step=now.step+1; map[next.a][next.b].prex=now.a; map[next.a][next.b].prey=now.b; v[a][next.b]=true; q.push(next); } if(now.b<b&&(!v[now.a][b]||map[now.a][b].step>now.step+1)) { v[now.a][b]=1; next=now; next.b=b; next.step++; next.prex=now.a; next.prey=now.b; strcpy(map[next.a][next.b].a,"FILL(2)"); map[next.a][next.b].step=now.step+1; map[next.a][next.b].prex=now.a; map[next.a][next.b].prey=now.b; v[next.a][next.b]=true; q.push(next); } // 清空 if(now.a!=0&&(!v[0][now.b]||map[0][now.b].step>now.step+1)) { v[0][now.b]=1; next=now; next.a=0; next.prex=now.a; next.prey=now.b; next.step++; strcpy(map[next.a][next.b].a,"DROP(1)"); map[next.a][next.b].step=now.step+1; map[next.a][next.b].prex=now.a; map[next.a][next.b].prey=now.b; q.push(next); } if(now.b!=0&&(!v[now.a][0]||map[now.a][0].step>now.step+1)) { v[now.a][0]=1; next=now; next.b=0; next.prex=now.a; next.prey=now.b; next.step++; strcpy(map[next.a][next.b].a,"DROP(2)"); map[next.a][next.b].step=now.step+1; map[next.a][next.b].prex=now.a; map[next.a][next.b].prey=now.b; q.push(next); } //从i到到j if(now.a!=0) { int aa,bb; int x=b-now.b;//需要到得量 if(x>=now.a) { aa=0;bb=now.b+now.a; } else { bb=b;aa=now.a-x; } if((!v[aa][bb]||map[aa][bb].step>now.step+1)) { next.a=aa;next.b=bb; next.prex=now.a;next.prey=now.b; next.step=now.step+1; map[aa][bb].step=now.step+1; strcpy(map[aa][bb].a,"POUR(1,2)"); map[next.a][next.b].prex=now.a; map[next.a][next.b].prey=now.b; v[next.a][next.b]=1; q.push(next); } } if(now.b!=0)//b->a { int aa,bb; int x=a-now.a;//需要到得量 if(x>=now.b) { aa=now.a+now.b; bb=0; } else { aa=a;bb=now.b-x; } if((!v[aa][bb]||map[aa][bb].step>now.step+1)) { next.a=aa;next.b=bb; next.prex=now.a;next.prey=now.b; next.step=now.step+1; map[aa][bb].step=now.step+1; strcpy(map[aa][bb].a,"POUR(2,1)"); map[next.a][next.b].prex=now.a; map[next.a][next.b].prey=now.b; v[next.a][next.b]=1; q.push(next); } } } return false; } int main() { while(cin>>a>>b>>c) { if(!bfs()) cout<<"impossible"<<endl; } return 0; }
  • 相关阅读:
    0121 集合类 ArrayList 的练习
    0121 有关接口的使用练习
    泛型相关知识
    0120 父类与子类创建、重写及转型练习
    0118练习 单例模式
    java设计模式 略版
    0117 面向对象OOP有关方法、类、构造方法及权限修饰符的练习
    0115 创建类并调用
    [luogu P2586] GCD 解题报告 (莫比乌斯反演|欧拉函数)
    POJ1284 Primitive Roots (原根)
  • 原文地址:https://www.cnblogs.com/zhangdashuai/p/4423208.html
Copyright © 2011-2022 走看看