1195.滑る
質問リンク
1つの文字列を基準に、残りの1つを基準の末尾に移動し、最短の幅を求めます.
以下に示すように、例入力1でアクション・プロシージャを表示します.
1. step1
2. step2
3. step3
4. step4
5. step5
6. step6
7. step7
8. step8
9. step9
data:image/s3,"s3://crabby-images/57526/575268b3de05e5b1be303756c7c1a0d9ca48f6bd" alt=""
1.トラブルシューティング
1つの文字列を基準に、残りの1つを基準の末尾に移動し、最短の幅を求めます.
以下に示すように、例入力1でアクション・プロシージャを表示します.
1. step1
data:image/s3,"s3://crabby-images/09686/09686c231a13f6076c8ccc8d65d9c3673038f750" alt=""
2. step2
data:image/s3,"s3://crabby-images/330cb/330cb308ec48211baf63cf4c4e43a19bd407c411" alt=""
3. step3
data:image/s3,"s3://crabby-images/e38b7/e38b7ba720296b449e3609c28af461bfbbeed61c" alt=""
4. step4
data:image/s3,"s3://crabby-images/d1930/d1930daa143c04eccb1c256c8b65ae30445c230c" alt=""
5. step5
data:image/s3,"s3://crabby-images/30d81/30d811918555ed7e70a42e07a58f081cf0748592" alt=""
6. step6
data:image/s3,"s3://crabby-images/1d3b5/1d3b5ca0a65982b3853efa1ece1d4159d4dae5b4" alt=""
7. step7
data:image/s3,"s3://crabby-images/2661d/2661d8839aca69d17dd55c0acdc890c3caeffcd5" alt=""
8. step8
data:image/s3,"s3://crabby-images/5472b/5472b4349410221f9e33451e8766b20857429b8b" alt=""
9. step9
data:image/s3,"s3://crabby-images/5e693/5e6933739339b86de22c21f78392488b12f8a647" alt=""
2.ソースコード
//킥다운
import java.util.*;
public class Main {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner sc = new Scanner(System.in);
String a1 = sc.nextLine();
String a2 = sc.nextLine();
System.out.println(simulation(a1, a2));
}
private static int simulation(String a1, String a2) {
char[] a = a1.toCharArray();
char[] b = a2.toCharArray();
int a_idx = a.length;
int len = a.length + b.length;
while (a_idx >= 0) {
int c = 0;
int b_idx = 0;
int start = a_idx;
boolean check = true;
while (start < a.length && b_idx < b.length) {
if (a[start] == '2' && a[start] == b[b_idx]) {
check = false;
break;
}
c++;
start++;
b_idx++;
}
if (check)
len = Math.min(len, a.length + b.length - c);
a_idx--;
}
int b_idx = 1;
while (b_idx < b.length) {
int c = 0;
a_idx = 0;
int start = b_idx;
boolean check = true;
while (start < b.length && a_idx < a.length) {
if (b[start] == '2' && b[start] == a[a_idx]) {
check = false;
break;
}
c++;
start++;
a_idx++;
}
if (check)
len = Math.min(len, a.length + b.length - c);
b_idx++;
}
return len;
}
}
Reference
この問題について(1195.滑る), 我々は、より多くの情報をここで見つけました https://velog.io/@jms8732/1195.-킥다운テキストは自由に共有またはコピーできます。ただし、このドキュメントのURLは参考URLとして残しておいてください。
Collection and Share based on the CC Protocol