結果
問題 | No.608 God's Maze |
ユーザー |
![]() |
提出日時 | 2017-12-08 02:45:11 |
言語 | Java (openjdk 23) |
結果 |
AC
|
実行時間 | 179 ms / 2,000 ms |
コード長 | 3,443 bytes |
コンパイル時間 | 2,524 ms |
コンパイル使用メモリ | 80,588 KB |
実行使用メモリ | 45,096 KB |
最終ジャッジ日時 | 2024-11-29 19:28:48 |
合計ジャッジ時間 | 10,846 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 65 |
ソースコード
import java.io.*;import java.util.*;class Main {static String s;static int[]zero,one;static int g(int[]x,int a){int ans=0;int[]oldx=x.clone();int n=x.length;if(x[a]==1)if(a==n-1)return 0x3fffffff;else{x[a]=0;x[a+1]=1-x[a+1];ans+=2;}int p=a;int last=-1;for(int i=a;i<n;++i)if(x[i]==1)last=i;while(true){int p2=p+1;while(p2<=last&&x[p2]!=0)p2++;if(p2>last){ans+=Math.max(last-p,0);break;}x[p2]=1;x[p2+1]=1-x[p2+1];if(last==p2+1)last=p2;ans+=p2-p+2;p=p2;}//System.err.println("g("+Arrays.toString(oldx)+","+a+")="+ans);return ans;}public static void main(String[] args) {MyScanner sc = new MyScanner();out = new PrintWriter(new BufferedOutputStream(System.out));int n=sc.nextInt()-1;s=sc.next();int l=s.length();int p=0,q=0;zero=new int[s.length()];one=new int[s.length()];for(int i=0;i<s.length();++i)if(s.charAt(i)=='.')zero[p++]=i;elseone[q++]=i;zero=Arrays.copyOf(zero,p);one=Arrays.copyOf(one,q);int[]t=new int[l];for(int i=0;i<l;++i)t[i]=s.charAt(i)=='#'?1:0;int[]u=t.clone();int x=one[0],y=one[q-1];System.err.println("x="+x+" y="+y);int m=Integer.MAX_VALUE;int st=-1;if(x<n){for(int i=x;i<n;++i)u[i]=1-u[i];st=x;}elsest=n;m=Math.min(m,Math.max(0,n-x)+g(u,st));u=t.clone();if(n<y){for(int i=n+1;i<=y;++i)u[i]=1-u[i];st=y;}elsest=n;for(int i=0;i<l/2;++i){int temp=u[i];u[i]=u[l-1-i];u[l-1-i]=temp;}m=Math.min(m,Math.max(0,y-n)+g(u,l-1-st));out.println(m);out.close();}// http://codeforces.com/blog/entry/7018//-----------PrintWriter for faster output---------------------------------public static PrintWriter out;//-----------MyScanner class for faster input----------public static class MyScanner {BufferedReader br;StringTokenizer st;public MyScanner() {br = new BufferedReader(new InputStreamReader(System.in));}String next() {while (st == null || !st.hasMoreElements()) {try {st = new StringTokenizer(br.readLine());} catch (IOException e) {e.printStackTrace();}}return st.nextToken();}int nextInt() {return Integer.parseInt(next());}long nextLong() {return Long.parseLong(next());}double nextDouble() {return Double.parseDouble(next());}String nextLine(){String str = "";try {str = br.readLine();} catch (IOException e) {e.printStackTrace();}return str;}}}