//2 字符串处理转换
//问题描述:
//在给定字符串中找出单词( “单词”由大写字母和小写字母字符构成,
//其他非字母字符视为单词的间隔,如空格、问号、数字等等;另外单个字母不算单词);
//找到单词后,按照长度进行降序排序,(排序时如果长度相同,则按出现的顺序进行排列),
//然后输出到一个新的字符串中;如果某个单词重复出现多次,则只输出一次;
//如果整个输入的字符串中没有找到单词,请输出空串。输出的单词之间使用一个“空格”隔开,最后一个单词后不加空格。
//要求实现函数:
//void my_word(charinput[], char output[])
//【输入】 char input[], 输入的字符串
//【输出】 char output[],输出的字符串
//【返回】 无
//示例
//输入:charinput[]="some local buses, some1234123drivers" ,
//输出:charoutput[]="drivers local buses some"
//输入:charinput[]="%A^123 t 3453i*()" ,
//输出:charoutput[]=""
#include<stdio.h>
#include<assert.h>
void my_word(char input[ ], char output[ ])
{
assert(input);
assert(output);
int flag = 1;//一个标识,为1表示遇到了非字母的字符
int i = 0; //作为扫描字符串的标识
int newp = 0; //作为存放调整后字符串的标识 //把字符串进行扫描,变成英语的句式 “(单词1)_(单词2)+(单词3)” 中间的间隔式非字母字符
while(input[i] != '\0') //此处i作为一个扫描指针,newp作为一个调整后的指针,存放符合要求的字符
{
if(( (input[i] < 'A' )||(input[i] > 'Z'&&input[i]<'a') || ( input[i] >'z'))&& (flag == 1) )//之前遇到了非字母,现在遇到的是非字母
{
i++;
}
else if(((input[i] >= 'a' && input[i] <= 'z') || (input[i] >='A'&& input[i] <='Z'))&& (flag == 1) )//之前遇到了非字母,现在遇到的是字母
{
input[newp++] = input[i++] ;
flag = 0;
} else if ( ((input[i] >= 'a' && input[i] <= 'z') || (input[i] >='A'&& input[i] <='Z'))&& (flag == 0) )//之前遇到了字母,现在遇到的是字母
{
input[newp++] = input[i++];
}
else //之前遇到了字母,现在遇到的是非字母
{
input[newp++] = input[i++] ;
flag = 1;
}
} input[newp] = '\0';
printf("%s\n",input); //输出调整后的字符 int NumOfNotchar = 0 ;//统计出字符串中的单词数,NumOfNotchar+1
i = 0;
while(input[i] != '\0' )
{
if( (input[i] < 'A' )||(input[i] > 'Z'&&input[i]<'a') || ( input[i] >'z')) //通过非字母的个数来判断调整后单词的个数
NumOfNotchar++;
i++;
}
newp = 0;
int lastpos = 0; //存放之前字符串中最长单词的长度的位置
int lastlength = 0; //存放之前字符串中最长单词的长度
for(int n = 0; n < NumOfNotchar ; n++ ) //
{
i = 0;
int maxlength = 0; //存放当前字符串中最长单词的长度
int length = 0; //记录单词的长度
int maxpos = 0;//存放当前字符串中最长单词的长度的位置
int flag2 = 0; //作为一个标识,判断当前单词与上一个单词是否一样 //当前字符串中的最个数
int Numofinput = 0;
while(input[i] != '\0' )
{
Numofinput++;
i++;
} i = 0; //作为扫描字符串的指针
int prepos = Numofinput; //prepos存放(再长度相同情况下最前面)最长单词的起始位置 while(i <= Numofinput )
{
if( ((input[i] >= 'a' && input[i] <= 'z') || (input[i] >='A'&& input[i] <='Z')) ) //遇到的是字母
{
length++;
i++;
continue;
}
else if (length >= maxlength && length!=1 ) //遇到非字母了
{ i++; maxpos = i-length-1 ; //暂时存放当前最大的单词的起始位置
if( length > maxlength) //除非你比最大的长度还大,否则不改变prepos起始位置,prepos存放(再长度相同情况下最前面)最长单词的起始位置
{
prepos = maxpos;
} maxlength = length;
length = 0; if( maxlength == lastlength ) //如果当前的最长字符和之前的字符等长,判断是否相等
{
for(int j = 0; j<maxlength; j++)
{
if(input[(prepos+j)] == output[(lastpos+j)])
{
;
}
else //说明当前字符和之前的字符是不相等的
break; }
if (j == (maxlength )) //说明当前字符和之前的字符是相等的
flag2 = 1;
continue;
}
}
else //遇到非字母了,但是之前的单词没有maxlength长
{
i++;
length = 0;
}
} if( flag2 != 1 ) //如果当前字符和之前的字符是不相等,就将这个字符放入output中
{
int j = newp;
lastpos = newp;
lastlength = maxlength;
for(j =prepos; j < (prepos+maxlength); j++ )
{
output[newp++] = input[j];
}
output[newp++] = ' ';
}
//把这个单词去掉
int start = prepos;
int end = prepos + maxlength; if(input[ end]== '\0') //如果只剩下一个空字符串了
{
input[ start] = input[end];
input[start-1]='\0';
}
else //把当前后面的到结尾全部往前移
{
start--;
while(input[ end]!= '\0')
{
input[ start++] = input[end++];
}
input[start]='\0';
}
} output[newp] = '\0';
printf("%s\n",output);
}
int main()
{
char input[] = "some local buses, some1234123drivers max max";
char output[1000];
printf("%s\n",input);
my_word(input, output);
return 0;
}

H面试程序(28):字符串处理转换的更多相关文章

  1. H面试程序(27):字串转换

    //1 字串转换 //问题描述: //将输入的字符串(字符串仅包含小写字母‘a’到‘z’),按照如下规则,循环转换后输出:a->b,b->c,…,y->z,z->a: //若输 ...

  2. H面试程序(10): 字符串包含问题

    题目描述:判断第二个字符串中的元素是否都能在第一个字符串中找到: 注意:和字符串的字串的问题有所区别,如第一个字符串为  abcdefg,第二个字符串为 aaabc,第二个字串还是包含于第一个字符串 ...

  3. H面试程序(11): 判断字符串是否包含子串问题

    题目描述:                        如字符串str1为''abcdef'''                       字符串str2为'' bc''; 则字符串str1中含有 ...

  4. H面试程序(12): 输出字符串中第一个只出现一次的字母

    题目描述: 若字符串str为'' sbdddsbfc'',则输出 f; 若字符串str为''aabbccdd'',则输出:字符串str中的字符都出现两次以上 #include <stdio.h& ...

  5. H面试程序(4):翻转句子中单词的顺序 .

    题目:输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变. 句子中单词以空格符隔开.为简单起见,标点符号和普通字母一样处理. 例如输入“I am a student.”,则输出“stude ...

  6. H面试程序(1)编写一个函数,要求输入年月日时分秒,输出该年月日时分秒的 下一秒

    编写一个函数,要求输入年月日时分秒,输出该年月日时分秒的下一秒. 如输入 2004 年 12 月 31 日 23 时 59 分 59 秒,则输出 2005年 1 月 1 日 0 时 0 分 0 秒. ...

  7. H面试程序(29):求最大递增数

    要求:求最大递增数 如:1231123451 输出12345 #include<stdio.h> #include<assert.h> void find(char *s) { ...

  8. H面试程序(15): 冒泡排序法

    #include<stdio.h> #include<assert.h> void display(int * a, int n) { for(int i = 0; i < ...

  9. H面试程序(16): 简单选择排序

    #include<stdio.h> #include<assert.h> void display(int * a, int n) { assert(a); for(int i ...

随机推荐

  1. POCO C++ lib开发环境构建

    Welcome Thank you for downloading the POCO C++ Libraries and welcome to the growing community of POC ...

  2. HDU 2815 Mod Tree

    不会,先搁着…… http://blog.csdn.net/acm_cxlove/article/details/7832197

  3. 74HC595的中文资料

    74HC595--具有三态输出锁存功能的8位串行输入.串行/并行输出移位寄存器 本文翻译自NXP的74HC595的datasheet 74HC595和74HCT595是带有存储寄存器和三态输出的8位串 ...

  4. 细数C++和C的差别

    C++语言是对C语言的扩展.所以熟悉C语言的人会发现.本书的第01~18章讲的内容基本上和C语言的内容差点儿相同. C++一方面对C语言的语法进行了改动.还有一方面又加入一些新的概念. C++中新增的 ...

  5. 如何自定义iOS中的控件

    本文译自 How to build a custom control in iOS .大家要是有什么问题,可以直接在 twitter 上联系原作者,当然也可以在最后的评论中回复我. 在开发过程中,有时 ...

  6. Xcode - 详解真机测试步骤

    第一种从iOS9.0之后推出的免费开发者账号 1.注册开发者 * 注册Apple ID * 使用Apple ID登录苹果开发者中心,注册成为开发者 * 此过程为免费,只是为了让普通的Apple ID具 ...

  7. centos下卸载jdk

    链接地址:http://blog.csdn.net/shuixin536/article/details/8954011 http://sunqiusong.email.blog.163.com/bl ...

  8. 控制台console使用MFC库函数,Cout输出CString的方法

    新建工程的时候选择:Win32 Console Application 在向导的地方勾选MFC头文件支持,确认即可 等待初始化文件完成后,VS2010会自动打开 项目名.cpp的文件 其中int _t ...

  9. 【转载】CentsOS系统inotify实时监控服务器文件(夹)定制事件处理程序

    原始博文和参考博文 1.CentsOS系统inotify实时监控服务器文件 2.Linux中让进程在后台运行的方法 3.linux inotify 监控文件系统事件 非常好 方法一 说明: 服务器系统 ...

  10. jmeter 压力测试 参数

    Aggregate Report 是 JMeter 常用的一个 Listener,中文被翻译为“聚合报告”.今天再次有同行问到这个报告中的各项数据表示什么意思,顺便在这里公布一下,以备大家查阅. 如果 ...