Newguy


私信TA

用户名:772007765

访问量:82107

签 名:

已秃人士

等  级
排  名 28
经  验 14597
参赛次数 3
文章发表 92
年  龄 0
在职情况 在职
学  校
专  业

  自我简介:

解题思路:

import java.util.*;
import java.util.concurrent.ArrayBlockingQueue;  
  
public class Main  {
	
	static class Node {  队列节点
		String s = null;
		String step = null;
		Node(String s, String step, char nc) {
			this.s = s;
			String ch = Character.toString(nc);
			if (step != null)          
				this.step = step.concat(ch);
			else
				this.step = new String(ch);
		}
		Node(String s){
			this.s = s;
		}
	}

	public static String change(String s, int num) {
		char[] resch = s.toCharArray();
		//上下交换
		if (num == 0) {
			for (int i = 0; i <= 3; i++) {
				char tmp = resch[i];
				resch[i] = resch[7-i];
				resch[7-i] = tmp;
			}
			return new String(resch);
		}
		//右移交换
		else if (num == 1) {
			char tmp = resch[3];
			for (int i = 3; i > 0; i--) 
				resch[i] = resch[i-1];
			resch[0] = tmp;
			tmp = resch[4];
			for (int i = 4; i < 7; i++) 
				resch[i] = resch[i+1];
			resch[7] = tmp;
			return new String(resch);
		} 
		//顺时针交换
		else {        
			char tmp = resch[2];
			resch[2] = resch[1];
			resch[1] = resch[6];
			resch[6] = resch[5];
			resch[5] = tmp;
			return new String(resch);
		}
	}
    public static void main(String args[]){  
    	Scanner input = new Scanner(System.in);
    	while (input.hasNext()) {
    		Queue<Node> queue = new LinkedList<>();
    		//用hash表避免超时,再加上状态压缩内存好看点
    		//因为各个数字不同,所以最后一位可忽略
    		boolean[] hash = new boolean[8765433]; 
    		String aim = new String(input.next());
    		queue.offer(p);
    		hash[Integer.valueOf(p.s) / 10] = true;
    		while (!queue.isEmpty()) {
    			Node first = queue.poll();  /出队
    			if (first.s.compareTo(aim) == 0) {
    				System.out.println(first.step);
    				break;
    			}	
    			for (int i = 0; i < 3; i++) {
    				String tmp = change(first.s, i);
    				int tmpi = Integer.valueOf(tmp) / 10;   //状态压缩
    				if (!hash[tmpi]) {
    					queue.offer(new Node(tmp, first.step, (char)(i + 'A')));
    					hash[tmpi] = true;
    				}					
    			}
    		}
    	}
    }  
}




注意事项:





参考代码:

 

0.0分

0 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换

万能编程问答

代码解释器

  评论区