每日算法刷题 Day7- 比较字符串大小,去掉多余的空格,单词替换
⭐每日算法题解系列文章旨在精选重点与易错的算法题,总结常见的算法思路与可能出现的错误,与笔者另一系列文章有所区别,并不是以知识点的形式提升算法能力,而是以实战习题的形式理解算法,使用算法。
🔥本文已收录于算法刷题系列专栏: 每日算法题解 欢迎订阅,持续更新。
@[toc]
23.忽略大小写比较字符串大小
一般我们用 strcmp 可比较两个字符串的大小,比较方法为对两个字符串从前往后逐个字符相比较(按 ASCII 码值大小比较),直到出现不同的字符或遇到 \0
为止。
如果全部字符都相同,则认为相同;如果出现不相同的字符,则以第一个不相同的字符的比较结果为准。
但在有些时候,我们比较字符串的大小时,希望忽略字母的大小,例如 Hello
和 hello
在忽略字母大小写时是相等的。
请写一个程序,实现对两个字符串进行忽略字母大小写的大小比较。
输入格式
输入为两行,每行一个字符串,共两个字符串。注意字符串中可能包含空格。
数据保证每个字符串的长度都不超过 80。
输出格式
如果第一个字符串比第二个字符串小,输出一个字符 <
。
如果第一个字符串比第二个字符串大,输出一个字符 >
。
如果两个字符串相等,输出一个字符 =
。
输入样例:
输出样例:
思路:
c_str 是 Borland 封装的 String 类中的一个函数,它返回当前字符串的首字符地址。
标准头文件<cstring>包含操作 c-串的函数库。这些库函数表达了我们希望使用的几乎每种字符串操作。
当调用库函数,客户程序提供的是 string 类型参数,而库函数内部实现用的是 c-串,因此需要将 string 对象,转化为 char*对象,而 c_str()提供了这样一种方法,它返回 const char*类型(可读不可改)的指向字符数组的指针。
24.去掉多余的空格
输入一个字符串,字符串中可能包含多个连续的空格,请将多余的空格去掉,只留下一个空格。
输入格式
共一行,包含一个字符串。
输出格式
输出去掉多余空格后的字符串,占一行。
数据范围
输入字符串的长度不超过 200200。保证输入字符串的开头和结尾没有空格。
输入样例:
输出样例:
思路
思路一:用 cin 过滤空格
思路二:双指针做法
思路三:移动的方法
25.单词替换
输入一个字符串,以回车结束(字符串长度不超过 100)。
该字符串由若干个单词组成,单词之间用一个空格隔开,所有单词区分大小写。
现需要将其中的某个单词替换成另一个单词,并输出替换之后的字符串。
输入格式
输入共 33 行。
第 1 行是包含多个单词的字符串 s;
第 2 行是待替换的单词 aa(长度不超过 100);
第 3 行是 a 将被替换的单词 bb(长度不超过 100)。
输出格式
共一行,输出将 s 中所有单词 a 替换成 b 之后的字符串。
输入样例:
输出样例:
代码
这里用到了 stringstream ssin(s),在头文件 #include<sstream>中, <sstream>定义了三个类:istringstream、ostringstream 和 stringstream,分别用来进行流的输入、输出和输入输出操作。<sstream>主要用来进行**数据类型转换。**比 sscanf,sprintf 更加安全。
stringstream 函数
基本用法:
格式是 stringstream ssin; ssin<<s; s 是个字符串,s 通常用 getline(cin,s)来获得。
此时的 ssin 相当于一个缓冲区,保存了字符串里面的所有字符。
然后可以通过 ssin>>a;把字符串赋给 a,a 可以是各种类型的,会跳过空格,与 cin 相似
版权声明: 本文为 InfoQ 作者【timerring】的原创文章。
原文链接:【http://xie.infoq.cn/article/ddca08081c86a2585342f8478】。未经作者许可,禁止转载。
评论