Artifact Content
Not logged in

Artifact e22cb888fb6353ea3b88a418a8cd465a58c187a6


import util;
import game;
import driver;

/*
interface Solver
{
	this(const(Game) g);
	char single_step();
}
*/

class Solver_0
{
	this(const(Game) g) {}
	char single_step() { return 'W'; }
}

class Solver_1
{
	int g_wc = 0;

	Game g;
	this(const(Game) g)
	{
		this.g = g.clone();
	}

	char single_step()
	{
		char c = act(g, death_move(g));
		g.command(c);
		return c;
	}

	string death_move(const(Game) g)
	{
		string death;
		foreach(char c; "UDLRW") {
			Game gg = g.clone();
			gg.command(c);
			if( !gg.cleared && gg.dead )
				death ~= c;
		}
		return death;
	}

	char act(const(Game) g, string death)
	{
		const Pos   ro = g.map.robot;
		const Pos[] la = g.map.lambdas();
		const Pos   li = g.map.lift;

		char c = 'W';
		if( la.empty ) {
			auto r = search(g, ro, li, death);
			c = r[0];
		} else {
			Tuple!(char,int)[] cand;
			foreach(lam; la)
				cand ~= search(g, ro, lam, death);
			sort!((Tuple!(char,int) c1, Tuple!(char,int) c2){
				if(c1[1] != c2[1])
					return c1[1] < c2[1];
				return c1[0] < c2[0];
			})(cand);
			c = cand[0][0];
		}
		if(c=='W') {
			g_wc++;
			if(g_wc > 10)
				c = 'A';
		}
		else
			g_wc = 0;
		return c;
	}

	Tuple!(char,int) search(in Game g, in Pos s, in Pos o, string death)
	{
		const(Pos)[] q = [o];
		bool[][] v = new bool[][](g.map.H+2, g.map.W+2);
		for(int step=1; q.length; ++step) {
			Pos[] q2;
			foreach(p; q) {
				int[] dy=[-1,+1,0,0];
				int[] dx=[0,0,-1,+1];
				for(int i=0; i<4; ++i) {
					int y = p.y+dy[i];
					int x = p.x+dx[i];
					if(v[y][x]) continue;
					if(y==s.y && x==s.x) {
						char c = "UDRL"[i];
						if( death.count(c) == 0 )
							return tuple(c,step);
					} else if(g.map[y,x]==' '||g.map[y,x]=='\\') {
						q2 ~= new Pos(y,x);
						v[y][x]=true;
					} else if(g.map[y,x]=='.' && g.map[y-1,x]!='*') {
						q2 ~= new Pos(y,x);
						v[y][x]=true;
					}
				}
			}
			q = q2;
		}
		q = [o];
		v = new bool[][](g.map.H+2, g.map.W+2);
		for(int step=1000; q.length; ++step) {
			Pos[] q2;
			foreach(p; q) {
				int[] dy=[-1,+1,0,0];
				int[] dx=[0,0,-1,+1];
				for(int i=0; i<4; ++i) {
					int y = p.y+dy[i];
					int x = p.x+dx[i];
					if(v[y][x]) continue;
					if(y==s.y && x==s.x) {
						char c = "UDRL"[i];
						if( death.count(c) == 0 )
							return tuple(c,step);
					} else if(g.map[y,x]==' '||g.map[y,x]=='\\') {
						q2 ~= new Pos(y,x);
						v[y][x]=true;
					} else if(g.map[y,x]=='.'/* && g[y-1,x]!='*'*/) {
						q2 ~= new Pos(y,x);
						v[y][x]=true;
					}
				}
			}
			q = q2;
		}
		return tuple('W', int.max);
	}
}