zoukankan      html  css  js  c++  java
  • 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
  • 相关阅读:
    HDU 1573: X问题
    HDU 1370: Biorhythms
    Break Number --AtCoder
    Cat Snuke and a Voyage --AtCoder
    Fennec VS. Snuke --AtCoder
    Splitting Pile --AtCoder
    Sharing Cookies --AtCoder
    GLB串
    派(Dispatch)
    你知道那棵杨树底下有什么吗
  • 原文地址:https://www.cnblogs.com/xiaobaibuhei/p/3276389.html
Copyright © 2011-2022 走看看