アットウィキロゴ

tetudou 7

package line;
 
 
public class pro {
 
    int number;
 
 
 
  int number_line;
  int[] a_line=new int[100001];
  int[] b_line=new int[100001];
  int[] d_line=new int[100001];
 
 
 
 
    public static void main(String[] args) {
        pro test=new pro();
    }
 
    pro(){
 
 
        number=100;
 
  faststep sub=new faststep();
  sub.number=number;
  sub.makedata();
  number_line=sub.number_line;
 a_line=sub.a_line;
 b_line=sub.b_line;
 d_line=sub.d_line;
 
 
 int tr;
 
  for(tr=1;tr<1000;tr++){
 
  trip sub2=new trip();
  sub2.number=number;
  sub2.number_line=number_line;
 sub2.a_line=a_line;
 sub2.b_line=b_line;
 sub2.d_line=d_line;
  sub2.makedata();
  number_line=sub2.number_line;
 a_line=sub2.a_line;
 b_line=sub2.b_line;
 d_line=sub2.d_line;
 
 
    }
 
 
    System.out.println(number_line);
 
 
    }
 
 
 
 
}
 
 
 
package line;
 
 
 
public class faststep {
 
       int number;
  int[] x=new int[101];
  int[] y=new int[101];
 
 
  int number_line;
  int[] a_line=new int[100001];
  int[] b_line=new int[100001];
  int[] d_line=new int[100001];
 
 
    void makedata(){
 
        int s,sx,tx;
        tx=0;
        for(s=1;s<11;s++){
         for(sx=1;sx<11;sx++){
         tx=tx+1;
         x[tx]=sx;
         y[tx]=s;
         } 
        }
 
        number=tx;
 
        number_line=0;
 
      plusx();
 
      plusy();
 
 
 
 
    }
 
    void plusx(){
 
          int ch,sx,h,s;
 
          int x1,y1;
 
        for(s=1;s<number+1;s++){
 
      x1=x[s]+1;
      y1=y[s];
 
      int sp=0;
 
      for(sx=1;sx<number+1;sx++){
      h=0;    
      if(x1==x[sx])h=h+1;
      if(y1==y[sx])h=h+1;
      if(h==2)sp=sx;
      }  
 
 
      ch=0;
     if(sp==0)ch=100;
      for(sx=1;sx<number_line+1;sx++){
      h=0;    
      if(a_line[sx]==s)h=h+1;
      if(b_line[sx]==sp)h=h+1;
      if(h==2)ch=100;
      }  
 
      for(sx=1;sx<number_line+1;sx++){
      h=0;    
      if(b_line[sx]==s)h=h+1;
      if(a_line[sx]==sp)h=h+1;
      if(h==2)ch=100;
      }  
 
 
      if(ch<50){
       number_line=number_line+1;   
       a_line[number_line]=s;
       b_line[number_line]=sp;
       d_line[number_line]=1;
      }  
 
 
     }
 
 
        }
 
 
 
      void plusy(){
 
        int s,sx,tx;
      int x1,y1,h;
 
  for(s=1;s<101;s++){
 
      x1=x[s];
      y1=y[s]+1;
 
      int sp=0;
 
      for(sx=1;sx<number+1;sx++){
      h=0;    
      if(x1==x[sx])h=h+1;
      if(y1==y[sx])h=h+1;
      if(h==2)sp=sx;
      }  
 
      int ch;
      ch=0;
     if(sp==0)ch=100;
      for(sx=1;sx<number_line+1;sx++){
      h=0;    
      if(a_line[sx]==s)h=h+1;
      if(b_line[sx]==sp)h=h+1;
      if(h==2)ch=100;
      }  
 
       for(sx=1;sx<number_line+1;sx++){
      h=0;    
      if(b_line[sx]==s)h=h+1;
      if(a_line[sx]==sp)h=h+1;
      if(h==2)ch=100;
      }  
 
      if(sp==0)ch=100; 
 
 
 
      if(ch<50){
       number_line=number_line+1;   
       a_line[number_line]=s;
       b_line[number_line]=sp;
       d_line[number_line]=1;
      }  
 
    }
 
 
 
 
 
 
    }
 
 
 
    int fast(){
        double n1=number*Math.random();
        int n2=(int)(Math.floor(n1))+1;
 
 
        return n2;
    }
 
 
 
 
 
 
 
 
 
 
}
 
 
 
package line;
 
 
public class trip {
     int number_line;
  int[] a_line=new int[100001];
  int[] b_line=new int[100001];
  int[] d_line=new int[100001];
 
  int number;
 
 
  int number_trip;
  int[] trip=new int[10001];
 
    void makedata(){
 
 
        gototrip();
  int s1,s2;      
 
  for(s1=1;s1<number_trip;s1++){
  for(s2=s1+1;s2<number_trip+1;s2++){
  int p=check_line(s1,s2);
  if(p>0)number_line=number_line+1;
  if(p>0)a_line[number_line]=trip[s1];
  if(p>0)b_line[number_line]=trip[s2];
  if(p>0)d_line[number_line]=met_line(s1,s2);
  }
  }
 
  for(s1=1;s1<number_trip;s1++){
  for(s2=s1+1;s2<number_trip+1;s2++){
  int p=check_line(s1,s2);
  int d21=99999;
  if(p>50)d21=met_line(s1,s2);
  int d22=0;
 if(p>50)d22=d_line[p];
  if(d22>d21)d_line[p]=d21;
  }
  }
 
 
 
    }
 
 
     int check_line(int s1,int s2){
 
     int t1=trip[s1];
     int t2=trip[s2];
 
     int sx,h,chx;
     chx=0;
     for(sx=1;sx<number_line+1;sx++){
      h=0;
     if(a_line[sx]==t1)h=h+1;
     if(b_line[sx]==t2)h=h+1;
     if(h==2)chx=sx;   
     }  
 
      for(sx=1;sx<number_line+1;sx++){
     h=0;
     if(b_line[sx]==t1)h=h+1;
      if(a_line[sx]==t2)h=h+1;
      if(h==2)chx=sx;
      }  
 
 
    return chx;
     }
 
 
     int met_line(int s1,int s2){
 
         int m1,d2;
         m1=0;
    int t1,t2,s;
    d2=0;
    for(s=s1;s<s2;s++){
    t1=trip[s];
    t2=trip[s+1];
    int mm=check_line(t1,t2);
    d2=d_line[mm]+d2;
    }
 
 
 
    return d2;
     }
 
 
 
 
 
 
     void gototrip(){
 
 
  int m=fast();
 
  number_trip=1;
  trip[1]=m;
  int mode=0; 
  while(mode<50){
  int m1=search(trip[number_trip]);
  int ch=check(m1);
  if(ch>50)mode=100;
  if(ch<50)number_trip=number_trip+1;
  if(ch<50)trip[number_trip]=m1;
  }
 
 
    }
 
       int check(int delta){
 
        int s,ch;
        ch=0;
        for(s=1;s<number_trip+1;s++){
        if(trip[s]==delta)ch=100;    
        }
        if(delta==0)ch=100;
 
        return ch;
 
 
    }
 
 
 
      int search(int delta){
 
        int sx,h,s;
        int[] z=new int[5000];
        s=0;
        for(sx=1;sx<number_line+1;sx++){
      if(a_line[sx]==delta)s=s+1;
        if(a_line[sx]==delta)z[s]=b_line[sx];
        }  
 
 
         for(sx=1;sx<number_line+1;sx++){
      if(b_line[sx]==delta)s=s+1;
      if(b_line[sx]==delta)z[s]=a_line[sx];
        }  
 
         double m1=s*Math.random();
         int m2=(int)(Math.floor(m1)+1);
 
         z[0]=0;
 
 
     return z[m2];
 
 
    }
 
 
 
 
 
 
    int fast(){
        double n1=number*Math.random();
        int n2=(int)(Math.floor(n1))+1;
 
 
        return n2;
    }
 
 
 
 
}
 
最終更新:2015年05月01日 09:37