結果
| 問題 |
No.225 文字列変更(medium)
|
| コンテスト | |
| ユーザー |
ぴろず
|
| 提出日時 | 2015-06-12 22:28:16 |
| 言語 | Java (openjdk 23) |
| 結果 |
AC
|
| 実行時間 | 177 ms / 5,000 ms |
| コード長 | 795 bytes |
| コンパイル時間 | 2,349 ms |
| コンパイル使用メモリ | 77,096 KB |
| 実行使用メモリ | 47,944 KB |
| 最終ジャッジ日時 | 2024-12-24 09:41:34 |
| 合計ジャッジ時間 | 6,838 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 22 |
ソースコード
package no225;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int m = sc.nextInt();
char[] s = sc.next().toCharArray();
char[] t = sc.next().toCharArray();
System.out.println(levenshteinDistance(s, t));
}
public static int levenshteinDistance(char[] s,char[] t) {
int n = s.length;
int m = t.length;
int[][] dp = new int[n+1][m+1];
for(int i=0;i<=n;i++) {
dp[i][0] = i;
}
for(int i=0;i<=m;i++) {
dp[0][i] = i;
}
for(int i=1;i<=n;i++) {
for(int j=1;j<=m;j++) {
dp[i][j] = Math.min(dp[i-1][j] + 1, Math.min(dp[i][j-1] + 1, dp[i-1][j-1] + (s[i-1] == t[j-1] ? 0 : 1)));
}
}
// System.out.println(Arrays.deepToString(dp));
return dp[n][m];
}
}
ぴろず