题目描述
对于一个长度为 K 的整数数列:A1, A2, . . . , AK,我们称之为接龙数列当且仅当 Ai 的首位数字恰好等于 Ai−1 的末位数字 (2 ≤ i ≤ K)。
例如 12, 23, 35, 56, 61, 11 是接龙数列;12, 23, 34, 56 不是接龙数列,因为 56的首位数字不等于 34 的末位数字。所有长度为 1 的整数数列都是接龙数列。
现在给定一个长度为 N 的数列 A1, A2, . . . , AN,请你计算最少从中删除多少个数,可以使剩下的序列是接龙序列?
输入格式
第一行包含一个整数 N。
第二行包含 N 个整数 A1, A2, . . . , AN。
输出格式
一个整数代表答案。
样例输入
复制
5 11 121 22 12 2023
样例输出
复制
1
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int[] dp = new int[10];//dp[i]表示以i结尾的最长长度
int max = 0;
for (int i = 0; i < n; i++) {
int x = sc.nextInt();
String s = String.valueOf(x);
int a = s.charAt(0) - 48;
int b = s.charAt(s.length() - 1) - 48;
dp[b] = Math.max(dp[b], dp[a] + 1);
max = Math.max(max, dp[b]);
}
System.out.println(n - max);
}
}