vidarwu 2021-07-26 19:22 采纳率: 100%
浏览 32
已结题

2801 字符串重组 1≤N≤10000000

现在有一个长度为N的字符串,全部由大写字母组成,每次可以从字符串的开头或者结尾挑选一个字符,加到一个新字符串后面,新字符串初始是空串,被挑选的字符要在原串里删除。要使最终的新字符串字典序最大,求出这个字典序最大的新字符串。

字典序是单词按字母顺序排列的方法。例如,“B"的字典序大于"A”;“ABD"的字典序大于"ABC”

  • 写回答

1条回答 默认 最新

  • 浪客 2021-07-26 19:57
    关注

    算法比较简单,比较字符串开头和结尾的字符,把大的复制到新字符串,并且从旧的删除,然后继续重复上面步骤,知道字符串为空。
    是这个意思吧?

    #include <iostream>
    #include <time.h>
    
    using namespace std;
    
    int N;
    char* initstr()
    {
        cout << "输入字符串长度:" << endl;
        cin >> N;
        char *s=new char[N];
        srand((unsigned)time(NULL));
        for(int i=0;i<N;i++)
        {
            s[i]=(char)((rand()%26)+'A');
        }    
        s[N]='\0';
        return s;    
    }
    
    int main()
    {
        char *str;
        str=initstr();
        cout << str << endl;
    
        char *str2=new char[N];
        int k=0;
    
        while(N>0)
        {
            if(*str>=str[N-1])
            {
                str2[k]=*str;
                str++;
            }
            else
            {
                str2[k]=str[N-1];
                str[N-1]='\0';
            }        
            N--;
            k++;
        }
    
        cout << str2 << endl;
    
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 8月7日
  • 已采纳回答 7月30日
  • 创建了问题 7月26日

悬赏问题

  • ¥15 ogg dd trandata 报错
  • ¥15 高缺失率数据如何选择填充方式
  • ¥50 potsgresql15备份问题
  • ¥15 Mac系统vs code使用phpstudy如何配置debug来调试php
  • ¥15 目前主流的音乐软件,像网易云音乐,QQ音乐他们的前端和后台部分是用的什么技术实现的?求解!
  • ¥60 pb数据库修改与连接
  • ¥15 spss统计中二分类变量和有序变量的相关性分析可以用kendall相关分析吗?
  • ¥15 拟通过pc下指令到安卓系统,如果追求响应速度,尽可能无延迟,是不是用安卓模拟器会优于实体的安卓手机?如果是,可以快多少毫秒?
  • ¥20 神经网络Sequential name=sequential, built=False
  • ¥16 Qphython 用xlrd读取excel报错