赞
踩
给定一个单词,如果该单词以er、ly或者ing后缀结尾, 则删除该后缀(题目保证删除后缀后的单词长度不为 0),否则不进行任何操作。
输入格式
输入一行,包含一个单词(单词中间没有空格,每个单词最大长度为 32)。
输出格式
输出按照题目要求处理后的单词。
格式说明
输出时每行末尾的多余空格,不影响答案正确性
样例输入
referer
样例输出
refe
本题目较为简单,只要输入一个字符串并且分别判断其最后两个或三个子字符串是否为"er" “ly” 或 "ing"即可。
利用string类的find()成员函数可以很方便的解决这个问题
find()函数原型如下:
size_type find(const string & str, size_type pos = 0) const
描述:从字符串的pos位置开始,查找子字符串str。如果找到,则返回该子字符串首次出现时其首字符的索引;否则,返回string::npos或-1
如果找到了"er"“ly”“ing”,则将其删除
注意:只删除一遍
利用string类的substr()成员函数可以很方便的解决这个问题
substr()函数原型如下:
String String::substr(int pos, int n)
描述:取出从pos的n个字符
利用以下语句将s赋值为s的子字符串:
s = s.substr(0, s.size() - 2);
或者是s = s.substr(0, s.size() - 3);
最后输出s即可
最终总体代码如下:
#include <iostream> #include <string> using namespace std; int main() { string s; cin >> s; if (s.find("er", s.size() - 2) != -1) s = s.substr(0, s.size() - 2); else if (s.find("ly", s.size() - 2) != -1) s = s.substr(0, s.size() - 2); else if (s.find("ing", s.size() - 3) != -1) s = s.substr(0, s.size() - 3); cout << s << endl; return 0; }
——Written by Ryan_LuoYuxuan
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。