/*(3‐2)所谓规范的文本是指:行首的第一个字符不能是空格;两个单词间只能有 1 个空
格且必须有 1 个空格;标点符号前面是单词中的最后一个字母,后面有且只能有一个
空格。
题目要求:输入一行字符,将其整理为规范的文本并输出。标点符号只考虑 , . ; ? !共 5 种。
如输入“: How old are your? I am 20.It is too old. ”输出:“: How old are your?
I am 20. It is too old.”
处理后结果解读:即要求输出的文本开头无前导空格,两个单词间如果有多个空格时只保留
1 个,标点符号后没有空格时,要加上 1 个。
提示:可以设置另一个字符数组,逐个检查输入的字符数组,保留的字符复制过去,多余的
空格不复制,增加需要补充的空格。当然也可以直接在原字符数组上做。
*算法说明:
开始先逐个判断是否为要求的字符串,如果是进行储存,放在另一个数组中
在进行分类,先进行字母储存(单词)
结束后,进行判断是否为五种字符,是,赋字符。否,赋空格。
然后在进行循环。
最后给储存数组赋结束字符'\0'。
输出储存数组字符。
*/
#include <iostream>
#include "string.h"
using namespace std;
int main()
{
char line[81], store_l[81];
int i = 0, s_i = 0;
cout <<"请输入一行字符:"<< endl;
cin.get(line, 81, '\n');//输入字符串
while (line[i] != '\0')
{
if ((line[i] >= 65&&line[i] <= 90) || (line[i] >= 97&&line[i] <= 122) || (line[i] >= 48&&line[i] <= 57) || line[i] == ','|| line[i] == '.'|| line[i] == ';'|| line[i] == '?'|| line[i] == '!')
{
while ((line[i] >= 65&&line[i] <= 90) || (line[i] >= 97&&line[i] <= 122) || (line[i] >= 48&&line[i] <= 57))
{
store_l[s_i] = line[i];
++i;
++s_i;
}
if (line[i] == ','|| line[i] == '.'|| line[i] == ';'|| line[i] == '?'|| line[i] == '!')
{
if (store_l[s_i - 1] == ' ')
{
store_l[s_i - 1] = line[i];
++i;
}
else
{
store_l[s_i] = line[i];
++i;
++s_i;
}
}
else
{
store_l[s_i] = ' ';
++s_i;
}
}
else
++i;
}
store_l[s_i] = '\0';
cout << store_l << endl;
system("PAUSE");
return 0;
}