アルゴリズムの勉強をしています。
他の方が書いたプログラムを見ているのですが、わからない部分があります。
問題は、「リング状の文字列 s の任意の位置から、時計回りに連続した文字をいくつか選んで、文字列 p が作れるかを判定するプログラムを作成してください。」というものです。
例えば、
文字列s: vanceknowledgetoadと入力して
文字列p: advanceという文字列ができていれば、Yesを返すといった具合です。
JAVA
1import java.io.*; 2 3class Main { 4 public static void main(String[] args) { 5 BufferedReader kb = new BufferedReader( new InputStreamReader( System.in ) ); 6 try { 7 String s = kb.readLine(); 8 String p = kb.readLine(); 9 10 int slen = s.length(); 11 int plen = p.length(); 12 int j = 0; 13 for( int i = 0; i<slen; i++ ) { 14 if( p.charAt( 0 ) == s.charAt( i ) ) { 15 int ij = i; 16 for( j = 0; j<plen; j++ ) { 17 ij = ( i+j ) % slen; 18 if( p.charAt( j ) != s.charAt( ij ) ) { 19 break; 20 } 21 } 22 } 23 if( plen == j ) { break; } 24 } 25 26 if( plen == j ) { 27 System.out.println( "Yes" ); 28 } else { 29 System.out.println( "No" ); 30 } 31 } catch( IOException e ) { 32 System.err.println( e ); 33 } 34 } 35} 36 37
最初のif (p.charAr(0) == s.charAr(i)の部分は、文字列pの最初の文字と文字列sが合うかを判定しているとわかります。
その後のfor以下がよくわかりません。
一番わからないのは、ij = (i+j) % slenの部分です。
なぜ、i+jをslenで割った余りを求めているのでしょうか?
for( int i = 0; i<slen; i++ ) { if( p.charAt( 0 ) == s.charAt( i ) ) { int ij = i; for( j = 0; j<plen; j++ ) { ij = ( i+j ) % slen; if( p.charAt( j ) != s.charAt( ij ) ) { break; } } } if( plen == j ) { break; }
考えているのですが、どうしてかよくわかりません。
ご回答頂けますと助かります。
よろしくお願い致します。
回答3件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2017/09/28 03:03