京都大学 情報学研究科 知能情報学専攻 2023年8月実施 情報学基礎 F2-2
Author
Description
設問1
2つの文字列の編集コストは、文字の置換・削除・挿入により、一方を他方に変換するのに必要最小限の操作(置換・削除・挿入)の数で定義できる。 なお、2つの文字列の長さは同じとする。以下の問いに答えよ。
(1) 文字列 PARIS を PAIRS に編集するコストを答えよ。
設問2
すべての頂点の次数が1または3であり、辺に向きがない、根無し無順序木について考える。
次数が1の頂点を葉と呼ぶ。
すべての辺には正の値の長さが与えられ、葉
(1) 3つの葉
(2) 4つの葉
Kai
設問1
The answer is
A = ["P", "A", "R", "I", "S"]
B = ["P", "A", "I", "R", "S"]
cost = [[0]*(len(A)+1) for _ in range(len(B)+1)]
for i in range(len(A)):
cost[i+1][0] = cost[i][0]+1
for j in range(len(B)):
cost[0][j+1] = cost[0][j]+1
for i in range(len(A)):
for j in range(len(B)):
c = 0 if A[i] == B[j] else 1
cost[i+1][j+1] = min(cost[i][j+1]+1, cost[i+1][j]+1, cost[i][j]+c)
for i in range(len(cost)):
print(cost[i])
設問2
(1)

(2)
