結果
問題 | No.225 文字列変更(medium) |
ユーザー |
![]() |
提出日時 | 2017-06-10 10:25:02 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 677 bytes |
コンパイル時間 | 1,546 ms |
コンパイル使用メモリ | 160,632 KB |
実行使用メモリ | 7,352 KB |
最終ジャッジ日時 | 2024-09-24 15:26:55 |
合計ジャッジ時間 | 2,125 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 1 WA * 21 |
コンパイルメッセージ
main.cpp: In function ‘int main()’: main.cpp:22:45: warning: overflow in conversion from ‘ll’ {aka ‘long long int’} to ‘int’ changes value from ‘100000000000’ to ‘1215752192’ [-Woverflow] 22 | REP(i, n + 1)REP(j, m + 1)d[i][j] = mod; | ^~~
ソースコード
#include"bits/stdc++.h" //#include<bits/stdc++.h> using namespace std; #define print(x) cout<<x<<endl; #define rep(i,a,b) for(int i=a;i<b;i++) #define REP(i,a) for(int i=0;i<a;i++) typedef long long ll; typedef pair<int, int> PI; typedef pair<int, PI> V; typedef vector<int> VE; const ll mod = 100000000000; int n, m; string s, t; int d[1002][1002]; int main() { cin >> n >> m; cin >> s; cin >> t; REP(i, n + 1)REP(j, m + 1)d[i][j] = mod; REP(i, n+1)d[i][0] = i; REP(i, m+1)d[0][i] = i; rep(i,1, n+1)rep(j,1, m+1) { int cost = s[i-1] == t[j-1] ? 0 : 1; d[i][j] = min(d[i - 1][j] + 1, min(d[i][j - 1] + 1, d[i - 1][i - 1] + cost)); } print(d[n][m]); return 0; }