SRM 389 Level2 1000
http://www.topcoder.com/stat?c=problem_statement&pm=8545&rd=11123
吉他有若干根弦,和弦有若干个音,按某弦的某节可以改变其音
求某和弦的最简单按发(各个弦按节最接近)
由于上限是6,数据比较小,
每个弦上需要考虑的点不超过12个
所以全部遍历也只有12^6种情况
又是递归,简单的深搜
  1 import java.util.*;
import java.util.*;
  2 import java.util.regex.*;
import java.util.regex.*;
  3 import java.text.*;
import java.text.*;
  4 import java.math.*;
import java.math.*;
  5 import java.awt.geom.*;
import java.awt.geom.*;
  6
  7 public class GuitarChords
public class GuitarChords
  8

 {
{
  9 //arrays
    //arrays
 10
 String[] notes =
    String[] notes =  {"A", "A#", "B", "C", "C#", "D", "D#", "E", "F", "F#", "G", "G#"};
{"A", "A#", "B", "C", "C#", "D", "D#", "E", "F", "F#", "G", "G#"};
 11 int best = Integer.MAX_VALUE;
    int best = Integer.MAX_VALUE;
 12 int[][] table;
    int[][] table;
 13 int[] dest;
    int[] dest;
 14 int[]  open;
    int[]  open;
 15 int[] ans;
    int[] ans;
 16 int L,N;
    int L,N;
 17 
    
 18 public int stretch(String[] strings, String[] chord)
    public int stretch(String[] strings, String[] chord)
 19
 
     {
{
 20 //length of the string and the chords
        //length of the string and the chords
 21 L = strings.length;
        L = strings.length;
 22 N = chord.length;
        N = chord.length;
 23 
        
 24 //table
        //table
 25 table = new int[L][24];
        table = new int[L][24];
 26 dest = new int[N];
        dest = new int[N];
 27 ans = new int[L];
        ans = new int[L];
 28 open = new int[L];
        open = new int[L];
 29 for(int[] t : table)
        for(int[] t : table)
 30 Arrays.fill(t, -1);
            Arrays.fill(t, -1);
 31 
        
 32 //data parse
        //data parse
 33 //positive numbers for chord notes, -1 for else
        //positive numbers for chord notes, -1 for else
 34 int i , j;
        int i , j;
 35
 for(i = 0 ; i < N ; ++ i)
        for(i = 0 ; i < N ; ++ i) {
{
 36 for(j = 0 ; j < 12 ; ++ j)
            for(j = 0 ; j < 12 ; ++ j)
 37 if(chord[i].compareTo(notes[j]) == 0)
                if(chord[i].compareTo(notes[j]) == 0)
 38 dest[i] = j;
                    dest[i] = j;
 39 }
        }
 40
 for( i = 0 ; i < L;  ++ i)
        for( i = 0 ; i < L;  ++ i) {
{
 41
 for(j = 0 ; j < 12; ++ j)
            for(j = 0 ; j < 12; ++ j) {
{
 42 if(strings[i].compareTo(notes[j]) == 0)
                if(strings[i].compareTo(notes[j]) == 0)
 43 open[i] = j;
                    open[i] = j;
 44 
                
 45 }
            }
 46
 for(int k = 0; k < N; ++ k)
            for(int k = 0; k < N; ++ k) {
{
 47 int temp = dest[k] - open[i];
                int temp = dest[k] - open[i];
 48 if(temp < 0)
                if(temp < 0)
 49 temp += 12;
                    temp += 12;
 50 table[i][temp] = dest[k];
                table[i][temp] = dest[k];
 51 table[i][temp+12] = dest[k];
                table[i][temp+12] = dest[k];
 52 }
            }
 53 }
        }
 54 //        for(int[] t:table){
//        for(int[] t:table){
 55 //            for(int in:t)
//            for(int in:t)
 56 //                System.out.print(in+" ");
//                System.out.print(in+" ");
 57 //            System.out.println();
//            System.out.println();
 58 //        }
//        }
 59 
            
 60 //search
        //search
 61 solve(0);
        solve(0);
 62 return best;
        return best;
 63 }
    }
 64 
    
 65
 void solve(int idx)
    void solve(int idx) {
{
 66 loop:
        loop:
 67
 for(int i = 0 ; i < 24; ++ i)
        for(int i = 0 ; i < 24; ++ i) {
{
 68 
            
 69 //get next valid note
            //get next valid note
 70 if(table[idx][i] == -1)
            if(table[idx][i] == -1)
 71 continue;
                continue;
 72 ans[idx] = i;
            ans[idx] = i;
 73 
            
 74 //come to the last string
            //come to the last string
 75
 if(idx == L-1)
            if(idx == L-1) {
{
 76 
                
 77 //check whether every note appears
                //check whether every note appears
 78 boolean[] app = new boolean[N];
                boolean[] app = new boolean[N];
 79 Arrays.fill(app, false);
                Arrays.fill(app, false);
 80
 for(int j = 0 ; j < L; ++ j)
                for(int j = 0 ; j < L; ++ j) {
{
 81
 for(int k = 0 ; k < N; ++ k)
                    for(int k = 0 ; k < N; ++ k) {
{
 82 if(table[j][ans[j]] == dest[k])
                        if(table[j][ans[j]] == dest[k])
 83 app[k] = true;
                            app[k] = true;
 84 }
                    }
 85 }
                }
 86 for(boolean b:app)
                for(boolean b:app)
 87 if(b == false)
                    if(b == false)
 88 continue loop;
                        continue loop;
 89 
                
 90 //get the lowest and the highest
                //get the lowest and the highest
 91 int[] temp = ans.clone();
                int[] temp = ans.clone();
 92 Arrays.sort(temp);
                Arrays.sort(temp);
 93 if(temp[L-1] == 0)
                if(temp[L-1] == 0)
 94 best = 0;
                    best = 0;
 95 int j;
                int j;
 96
 for(j = 0 ; j < L-1; ++ j)
                for(j = 0 ; j < L-1; ++ j) {
{
 97 if(temp[j]!=0)
                    if(temp[j]!=0)
 98 break;
                        break;
 99 }
                }
100 int diff = temp[L-1] - temp[j] + 1;
                int diff = temp[L-1] - temp[j] + 1;
101 
                
102 //update the answer
                //update the answer
103 if(diff<best)
                if(diff<best) 
104 best = diff;
                    best = diff;
105 continue ;
                continue ;
106 }
            }
107 
            
108 //search next position
            //search next position
109 solve(idx+1);
            solve(idx+1);
110 }
        }
111 }
    }
112 }
}