1、计算字符串最后一个单词的长度,单词以空格隔开,字符串长度小于5000;
判断条件:当字符不为空格或换行时字符串长度++
使用动态数组来做,vector arr;
输入的字符串依次存入数组中
最后返回最后一个输入的字符串
#include <iostream>
#include <string>
#include <vector>
using namespace std;
int main()
{
string str; // 即将输入的字符串
vector<string> arr // 创建储存的动态数组
while(cin >> str) // 当从键盘有输入时
{
// 将输入的字符串存储进此动态数组中
arr.push_back(str);
}
// 输出此字符串的最后一个字符的长度
cout << arr[arr.size()-1].length << endl;
return 0;
}
计算某字符出现次数
(输入一个字符串,然后输入一个数组,给一个计数的,
循环字符串里的字符,如果与输入的单个字符相同则数量+1,不区分大小写+32也一样
加1)
描述:写出一个程序,接受一个由字母、数字和空格组成的字符串,和一个字符,
然后输出输入字符串中该字符的出现次数。(不区分大小写字母)
数据范围:1 <= n <= 1000
#include <iostream>
#include <string>
using namespace std;
int main()
{
string str;
char ch;
int count = 0;
cin >> str;
cin >> ch;
for(int i=0;i<str.size();i++)
{
if(str[i] = ch)
{
count++;
}
if(str[i]+32 = ch)
{
count++;
}
}
cout << count << endl;
return 0;
}
字符串分隔:
连续输入字符串,请按长度为8拆分每个字符串并进行输出
长度不是8整数倍的字符创请在后边补零,空字符创不处理
首先输入一个字符串,当该字符串是否大于8时截取8个
然后将剩下的字符串重新放入
#include <iostream>
#include <string>
int main()
{
string str;
while(getlin(cin,str))
{
while(str.size() > 8)
{
//截取前8个字符并进行输出
cout << str.substr(0,8)<< endl; // 这个即从0开始截取8个字符
// 将剩下不足8个的重新放入字符串
str = str.substr(8,str.size()-8);
}
获取剩下字符串的长度
int len = str.size();
// 如果字符串的长度刚好等于8
if(len == 8)
{
cout << str << endl;
}
else
{
for(int i = len; i < 8; i++)
{
str += '0';
}
cout << str << endl;
}
}
return 0;
}
前面基本是字符串的存放以及对需要满足的条件进行判断,续。。。。。