题目
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/reverse-words-in-a-string
代码
#include <QCoreApplication>
#include <QDebug>
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
QString oldStr = " I love you ";
qDebug() << "oldStr:" << oldStr;
QStringList strList = oldStr.split(' ');//拆分句子里所有的单词
QString newStr;
for(int i = strList.size() - 1; i >= 0 ; --i)
{
if(strList[i].compare("") != 0)//排除掉无用的字符串
{
newStr += strList[i] + " ";//逆序拼接
}
}
newStr.chop(1);//删除多余空格
qDebug() << "newStr:" << newStr;
return a.exec();
}
结果
解析
题目要求反转一个字符串,字符串里都是英语单词,只翻转单词的顺序。那么只需将每个单词看成个体,得到后再进行逆序输出即可。
QT中QString类中用split方法按需切割后得到QStingList集合,如果空格连续出现,则集合中和出现空字符串。
("", "I", "", "love", "", "you", "")
在进行逆序输出时,需要排除掉这些空字符串,用compare比对即可。最后删去尾部的空格,即可得到反转后的字符串。