蓝桥 历届试题 字串排序【第十一届】【省赛】【A组】

一.问题描述

小蓝最近学习了一些排序算法,其中冒泡排序让他印象深刻。

在冒泡排序中,每次只能交换相邻的两个元素。

小蓝发现,如果对一个字符串中的字符排序,只允许交换相邻的两个字符,则在所有可能的排序方案中,冒泡排序的总交换次数是最少的。

例如,对于字符串 lan 排序,只需要 1 次交换。对于字符串 qiao 排序,总共需要 4 次交换。

小蓝的幸运数字是 V,他想找到一个只包含小写英文字母的字符串,对这个串中的字符进行冒泡排序,正好需要 V 次交换。请帮助小蓝找一个这样的字符串。如果可能找到多个,请告诉小蓝最短的那个。如果最短的仍然有多个,请告诉小蓝字典序最小的那个。请注意字符串中可以包含相同的字符。

输入格式

输入一行包含一个整数 V,为小蓝的幸运数字。

输出格式

输出一个字符串,为所求的答案。

样例输入">样例输入">样例输入">样例输入">样例输入">样例输入">样例输入

4

Data

样例输出

bbaa

Data

样例输入

100

Data

样例输出

jihgfeeddccbbaa

二、在本题中,我最初的思考是,根据输入的V,因为我不清楚最开始所要输出的字符有多少个,所以打算从零个字符开始,再逐步 往上加字符,找到最终所要输出的字符,可是显而易见这样子太过麻烦。尝试写了写,果然卡在不知道如何将字符的长度加(即二十六个字符不知道加哪一个)

改进:

(1)求最小字符串长度

这道题所用的是冒泡排序,对于字符串长度为N的最坏情况需要比较N*(N-1)/2次,那换句话说,如果给出了比较次数为n,那么我就可以求出其最小的字符长度

Scanner input=new Scanner(System.in);
int v=input.nextInt();
//求最小的字符长度
int str_length=0;
for(;v>str_length*(str_length-1)/2;str_length++);

(2)冒泡排序最坏情况是由字符串全部逆序(即降序)造成的,我现在已经知道冒泡排序的最坏情况下的需要比较次数为N*(N-1)/2次,小蓝给的排序次数是V次,那么中间的差值(比如为x)就是用来将所能达到的最后的值提到前面来。这时问题又来了,此时是不是最小的字典序,给个例子

目标字符串经过100次交换后,得到正序字符串abcdefghijklmno,
而完全逆序的字符串onmlkjihgfedcba变成正序字符串需要105次交换,那么将完全逆序的字符串交换5次后,便能得到答案。.而要求字典序最小,那么将j交换5次提到字符串最前面,就得到了最小的情况
 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值