import java.util.Arrays;

public class ABC{
        private static void swap(int i, int j, Object... arr){
                Object tmp = arr[i];
                arr[i] = arr[j];
                arr[j] = tmp;
        }
        
        public static boolean canMakeWord(String word, String... blocks) {
            if(word.length() == 0)
                return true;
         
            char c = Character.toUpperCase(word.charAt(0));
            for(int i = 0; i < blocks.length; i++) {
                String b = blocks[i];
                if(Character.toUpperCase(b.charAt(0)) != c && Character.toUpperCase(b.charAt(1)) != c)
                    continue;
                swap(0, i, blocks);
                if(canMakeWord(word.substring(1), Arrays.copyOfRange(blocks, 1, blocks.length)))
                    return true;
                swap(0, i, blocks);
            }
         
            return false;
        }
        
        public static void main(String[] args){
                String[] blocks = {"BO", "XK", "DQ", "CP", "NA", 
                                "GT", "RE", "TG", "QD", "FS", 
                                "JW", "HU", "VI", "AN", "OB", 
                                "ER", "FS", "LY", "PC", "ZM"};

                System.out.println("\"\": " + canMakeWord("", blocks));
                System.out.println("A: " + canMakeWord("A", blocks));
                System.out.println("BARK: " + canMakeWord("BARK", blocks));
                System.out.println("book: " + canMakeWord("book", blocks));
                System.out.println("treat: " + canMakeWord("treat", blocks));
                System.out.println("COMMON: " + canMakeWord("COMMON", blocks));
                System.out.println("SQuAd: " + canMakeWord("SQuAd", blocks));
                System.out.println("CONFUSE: " + canMakeWord("CONFUSE", blocks));
                
        }
}