字符串操作


```cpp
/*
每一个序列号是一个字符串记为 S,只包含字母,数字以及“(分隔符)。
其中,N个'-'将字符串分成了 N + 1组,给你一个数字K,请你重新格式化序列号,
使其除第1个分组外每个分组恰好包含 K 个字符,第一个分组包含的字符个数必须小于等于K,
但至少要包含 1字母。两个分组之间需要‘-’隔开,
并目将所有的小写字母转换为大写字母.给定非空字符串 S 和数字 K,按照上面描述的规则进行格式化。
示例如下
输入 : S = "5F3Z-2e-9-w",K = 4
		
输出 : 5F3Z-2E9W
提示.
1、S 的长度可能很长,请按需分配大小。K 为正整数
2、每个输入的'="左右各有一个空格,后面有一个空格
3、如果无法按要求格式化,输出Error
样例输入: S = "5F3Z-2e-9-w",K = 4
样例输出: 5F3Z-2E9W
*/
#include
#include
#include
#include
using namespace std;

int main()
{
	string s;
	getline(cin, s);
	stringstream ss(s);
	//按 ,分割
	string s1, s2;
	getline(ss, s1, ',');
	getline(ss, s2, ',');
	
	//去除‘"S = "’
	string s1_sub = s1.substr(5, s1.length() - 6);
	//cout << s1_sub;
	//去除'-'
	string s1_sub1(s1_sub.length(), ' ');//定义大小,用空格初始化
	for (int i = 0,j=0; i < s1_sub.length(); i++)
	{
		if (s1_sub[i] != '-')
		{
			s1_sub1[j++] = s1_sub[i];
		}
	}
	//转成大写
	for (int i = 0; i < s1_sub1.length(); i++)
	{
		if (s1_sub1[i] >= 'a' && s1_sub1[i] <= 'z')
		{
			s1_sub1[i] -= 32;
		}
	}
	//cout << s1_sub1;
	//cout << s1_sub1;
	//提取k
	string s2_sub = s2.substr(4, s2.length() - 4);
	//cout << s2_sub;
	int k = stoi(s2_sub);
	//倒序遍历
	string result; 
	string str = "-";

	//重新计算s1_sub1大小
	int length = 0;
	for (int i = 0; i < s1_sub1.length(); i++)
	{
		if (s1_sub1[i] != ' ')
		{
			length++;
		}
	}

	for (int j = length; j > 0; j-=4)
	{
		if(j!= length)
		{ 
			s1_sub1.insert(j, str);
		}
	}
	cout << s1_sub1;
	//判断是否有字母
	stringstream ss2(s1_sub1);
	string s3;
	int flag = 0;
	while (getline(ss2, s3, '-'))
	{
		for (int i = 0; i < s3.length(); i++)
		{
			if (s3[i] >= 'A' && s3[i] <= 'Z')
			{
				flag++;
			}
		}
		if (flag == 0)
		{
			cout << "Error";
			break;
		}
		flag = 0;
	}
	
	system("pause");
	return 0;

}



你可能感兴趣的:(嵌入式秋招,算法)