UVa 10602

  题目大意:有一个编辑器,它有两种命令,“重复上一个单词” 和 “删除前一个字母”,给出一系列字符串,求最少的敲击键盘的次数。

  题目中强调第一个敲的单词必须是给的第一个单词,于是就考虑按照单词与第一个单词的前缀相似度进行排序,可是接下来就...发现网上的方法是直接对所有字符串排序,然后对排序的字符串进行处理,本以为那样输出与题中要求的“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                 
View Code
原文地址:https://www.cnblogs.com/xiaobaibuhei/p/3276389.html