博客
关于我
字符串排序
阅读量:439 次
发布时间:2019-03-06

本文共 935 字,大约阅读时间需要 3 分钟。

题目描述

编写一个程序,将输入字符串中的字符按如下规则排序。

规则1:英文字母从AZ排列,不区分大小写。

      如,输入:Type 输出:epTy

规则2:同一个英文字母的大小写同时存在时,按照输入顺序排列。

    如,输入:BabA 输出:aABb

规则3:非英文字母的其它字符保持原来的位置。

    如,输入:By?e 输出:Be?y

样例:

    输入:

   A Famous Saying: Much Ado About Nothing(2012/8).

    输出:

   A aaAAbc dFgghhiimM nNn oooos Sttuuuy (2012/8).

输入描述:
 
输出描述:
 
输入例子:
A Famous Saying: Much Ado About Nothing (2012/8).
输出例子:
A aaAAbc dFgghh: iimM nNn oooos Sttuuuy (2012/8).

题目思路:

受教于一位大神

先把字符的挑出来,保存进pair中,first键值保存字符,second保存位置。

挑出来之后sort排序,里面用了lambda表达式,如果转换小写之后相同,按照位置从小到大排,不相同统一按照小写字符a~z排序。
然后排序完成之后的arr重新放入原来的字符串,保证了非字母字符的位置不变。最后输出

代码:

#include
using namespace std;const int MAXN=1005;pair
ans[MAXN];bool cmp(pair
a,pair
b){ if(tolower(a.first)==tolower(b.first)) return a.second
还有lambda表达式形式的cmp

sort(ans,ans+index,[](pair
a,pair
b)->bool{ if(tolower(a.first)==tolower(b.first)) return a.second

转载地址:http://mvjyz.baihongyu.com/

你可能感兴趣的文章
Netty工作笔记0030---NIO与零拷贝原理剖析
查看>>
Netty工作笔记0034---Netty架构设计--线程模型
查看>>
Netty工作笔记0050---Netty核心模块1
查看>>
Netty工作笔记0057---Netty群聊系统服务端
查看>>
Netty工作笔记0060---Tcp长连接和短连接_Http长连接和短连接_UDP长连接和短连接
查看>>
Netty工作笔记0063---WebSocket长连接开发2
查看>>
Netty工作笔记0068---Protobuf机制简述
查看>>
Netty工作笔记0070---Protobuf使用案例Codec使用
查看>>
Netty工作笔记0072---Protobuf内容小结
查看>>
Netty工作笔记0074---handler链调用机制实例1
查看>>
Netty工作笔记0077---handler链调用机制实例4
查看>>
Netty工作笔记0081---编解码器和处理器链梳理
查看>>
Netty工作笔记0083---通过自定义协议解决粘包拆包问题1
查看>>
Netty工作笔记0084---通过自定义协议解决粘包拆包问题2
查看>>
Netty工作笔记0085---TCP粘包拆包内容梳理
查看>>
Netty常用组件一
查看>>
Netty常见组件二
查看>>
netty底层——nio知识点 ByteBuffer+Channel+Selector
查看>>
netty底层源码探究:启动流程;EventLoop中的selector、线程、任务队列;监听处理accept、read事件流程;
查看>>
Netty心跳检测
查看>>