题目大意:有一个编辑器,它有两种命令,“重复上一个单词” 和 “删除前一个字母”,给出一系列字符串,求最少的敲击键盘的次数。
题目中强调第一个敲的单词必须是给的第一个单词,于是就考虑按照单词与第一个单词的前缀相似度进行排序,可是接下来就...发现网上的方法是直接对所有字符串排序,然后对排序的字符串进行处理,本以为那样输出与题中要求的“Remember that the first word must be pressed first!”不符合,可是提交后竟然AC了!这...而且为什么这么做也想不明白...先放一放吧,下面是按网上方法的代码:
1 #include <cstdio> 2 #include <iostream> 3 #include <string> 4 #include <algorithm> 5 using namespace std; 6 #define MAXN 100+10 7 8 string str[MAXN]; 9 10 int main() 11 { 12 #ifdef LOCAL 13 freopen("in", "r", stdin); 14 #endif 15 int T; 16 scanf("%d", &T); 17 while (T--) 18 { 19 int n; 20 scanf("%d", &n); 21 for (int i = 0; i < n; i++) 22 cin >> str[i]; 23 sort(str, str+n); 24 int ans = str[0].size(); 25 for (int i = 1; i < n; i++) 26 { 27 int k = 0; 28 for (int j = 0; j < str[i-1].size(); j++) 29 { 30 if (str[i-1][j] == str[i][j]) k++; 31 else break; 32 } 33 ans += str[i].size() - k; 34 } 35 printf("%d ", ans); 36 for (int i = 0; i < n; i++) 37 cout << str[i] << endl; 38 } 39 return 0; 40 } 41