zoukankan      html  css  js  c++  java
  • CSU 1119 Collecting Coins

    bfs+dfs

    很复杂的搜索题。

    因为数据很小,rock最多只有5个,coin最多只有10个,移动rock最多4^5=1024种状态;

    思路:

      每次先把当前状态能拿到的coin拿走,并将地图当前位置设为'.' (拿走coin的位置为空)

      拿走coin后,在搜索一次,碰到rock判断是否能push动,能的话建立一个新地图,rock所在点设为'.' (空),rock移动到的点设为'X' (只能移动一次)。就这样递归下去,因为只有5个rock,最对递归5层。

      每次扫描完当前状态地图和以前拿到的最大值比较一下,取较大值 (有时候不移动rock拿到的coin更多!)

    ps:开始为了少设置一个变量偷懒,结果得不偿失,卡了好久。。。看来以后要小心点,不要随便改动前面的值,宁可多敲点也别犯这种低级错误。。。

      1 #include <iostream>
      2 #include <cstring>
      3 #include <cstdio>
      4 #include <algorithm>
      5 #include <cmath>
      6 #include <queue>
      7 using namespace std;
      8 
      9 char map[1050][20][20];  //第一维其实只要5就够了,当时一看状态1024就没多想,反正1024也没关系,数据小~~
     10 int visit[1050][20][20];
     11 int n,m,ma;
     12 
     13 int dir[4][2]={0,1,0,-1,1,0,-1,0};
     14 
     15 struct node {
     16     int x,y;
     17 }st;
     18 
     19 void cpy (int d,int s){
     20     for (int i=0;i<n;i++)
     21         for (int j=0;j<m;j++)
     22             map[d][i][j]=map[s][i][j];
     23 }
     24 
     25 void rvisit (int o){
     26     for (int i=0;i<n;i++)
     27         for (int j=0;j<m;j++)
     28             visit[o][i][j]=0;
     29 }
     30 
     31 int bfs (int o,int ans,node st){//cout<<st.x<<" "<<st.y<<endl;
     32     node a,b,c;
     33     queue<node> q;
     34     while (!q.empty())
     35         q.pop ();
     36     q.push (st);
     37     rvisit (o);
     38     visit[o][st.x][st.y]=1;
     39     while (!q.empty ()){
     40         a=q.front ();
     41         q.pop ();
     42         int xx,yy;
     43         for (int i=0;i<4;i++){
     44             xx=a.x+dir[i][0];
     45             yy=a.y+dir[i][1];
     46             if (visit[o][xx][yy])
     47                 continue ;
     48             if (xx<0||xx>=n||yy<0||yy>=m)
     49                 continue ;
     50             if (map[o][xx][yy]=='X'||map[o][xx][yy]=='O')
     51                 continue ;
     52             if (map[o][xx][yy]=='C'){
     53                 ans++;
     54                 map[o][xx][yy]='.';
     55             }
     56             b.x=xx;b.y=yy;
     57             q.push (b);
     58             visit[o][xx][yy]=1;
     59         }
     60     }
     61     ma=max (ma,ans);
     62     q.push (st);
     63     rvisit (o);
     64     visit[o][st.x][st.y]=1;
     65     while (!q.empty ()){
     66         a=q.front ();//if (o==0)cout<<o<<":"<<a.x<<" "<<a.y<<endl;
     67         q.pop ();
     68         int xx,yy;
     69         for (int i=0;i<4;i++){
     70             xx=a.x+dir[i][0];
     71             yy=a.y+dir[i][1];
     72             if (visit[o][xx][yy])
     73                 continue ;
     74             if (xx<0||xx>=n||yy<0||yy>=m)
     75                 continue ;
     76             if (map[o][xx][yy]=='X')
     77                 continue ;
     78             if (map[o][xx][yy]=='O'){
     79                 int xxx,yyy;
     80                 xxx=xx+dir[i][0];
     81                 yyy=yy+dir[i][1];
     82                 if (xxx<0||xxx>=n||yyy<0||yyy>=m)
     83                     continue ;
     84                 if (map[o][xxx][yyy]=='.'){
     85                     cpy (o+1,o);
     86                     map[o+1][xx][yy]='.';
     87                     map[o+1][xxx][yyy]='X';//cout<<o<<":"<<a.x<<" "<<a.y<<"|"<<xx<<" "<<yy<<"|"<<xxx<<" "<<yyy<<endl;
     88                     c.x=xx;c.y=yy;
     89                     bfs (o+1,ans,c);
     90                 }
     91                 
     92                 continue ;
     93             }
     94             b.x=xx;b.y=yy;//if (o==0) cout<<a.x<<" "<<a.y<<"|"<<xx<<" "<<yy<<endl;
     95             q.push (b);
     96             visit[o][xx][yy]=1;
     97         }
     98     }
     99 }
    100 
    101 int main (){
    102     int t;
    103     scanf ("%d",&t);
    104     while (t--){
    105         scanf ("%d%d",&n,&m);
    106         for (int i=0;i<n;i++){
    107             scanf ("%s",map[0][i]);
    108             for (int j=0;j<m;j++){
    109                 if (map[0][i][j]=='S'){
    110                     st.x=i;st.y=j;
    111                     //map[0][i][j]='.';
    112                 }
    113             }
    114         }//cout<<st.x<<" "<<st.y<<endl;cout<<map[0][st.x][st.y]<<endl;
    115         ma=0;
    116         bfs (0,0,st);
    117         printf ("%d
    ",ma);
    118     }
    119     return 0;
    120 }
  • 相关阅读:
    Android -- BroadCastReceiver的简单使用
    iOS-UITextField 全面解析
    iOS判断对象相等 重写isEqual、isEqualToClass、hash
    iOS开发 之 不要告诉我你真的懂isEqual与hash!
    浅谈 Objective-C 下对象的初始化
    iOS学习之Object-C语言继承和初始化方法
    Objective-c 中如何重写父类的初始化方法
    OC学习篇之---类的初始化方法和点语法的使用
    iOS7实现带文本输入框的UIAlertView及获取TextField文本内容
    UIALertView的基本用法与UIAlertViewDelegate对对话框的事件处理方法
  • 原文地址:https://www.cnblogs.com/gfc-g/p/3953346.html
Copyright © 2011-2022 走看看