1、字符串内增加其它符号时:
要求:字符中所有出现的数字前后加上符号“*”,其他字符保持不变。
思路遇到数字先输出符号,然后判断下一位是否为数字,若是,for循环内手动增加判断值i的大小;若不是数字,直接输出。
#include <iostream>
#include <string>
#include <vector>
using namespace std;
int main()
{
string s,b;
int len=0;
while(cin>>s)
{
len=s.length();
for(int i=0;i<len;i++)
{
if(s[i]>='0'&&s[i]<='9')
{
cout<<'*'<<s[i];
int j=1;
//输出连续数字
while(s[i+j]>='0'&&s[i+j]<='9')
{
cout<<s[i+j];
j++;
}
cout<<'*';
i=i+j-1;//手动增加i的值
}
else cout<<s[i];
}
cout<<endl;
}
}
2、字符串排序(字母顺序,符号位置不变)
要求:编写一个程序,将输入字符串中的字符按如下规则排序。
规则 1 :英文字母从 A 到 Z 排列,不区分大小写。
如,输入: Type 输出: epTy
规则 2 :同一个英文字母的大小写同时存在时,按照输入顺序排列。
如,输入: BabA 输出: aABb
规则 3 :非英文字母的其它字符保持原来的位置。
如,输入: By?e 输出: Be?y
思路先将字母排序放入容器,然后依次将容器内字符与原字符串比较,原字符串中是字符的按照容器中字符顺序依次输出,原字符串是符号的,直接输出符号。
#include<iostream>
#include<string>
#include<vector>
using namespace std;
int main()
{
string s;
int len=0;
vector<char>list;
while(getline(cin, s))
{
len=s.size();
//先将字母排序放入容器
for(int i=0;i<26;i++)
{
for(int j=0;j<len;j++)
{
if((s[j]-'a'==i)||(s[j]-'A'==i))
{
list.push_back(s[j]);
}
}
}
//原字符串与容器内比较
for(int k=0,f=0;(k<len)&&(f<list.size());k++)
{
if((s[k]>= 'a' && s[k] <= 'z') || (s[k] >= 'A' && s[k] <= 'Z'))
{
s[k]=list[f++];
}
}
cout<<s<<endl;
list.clear();
}
}