//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. DropBox为什么一直那么红——靠用户体验,旗帜鲜明,它要保存的是你的重要随身资料,并且开放API

    链接:http://www.zhihu.com/question/19705960/answer/71742127来源:知乎 看到这个问题竟然从11年答到现在,有趣的是这几年里国内云存储行业变化也是蛮 ...

  2. HDU1181【有向图的传递闭包】

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1181 题意很简单. 有用并查集做的.我这里用传递闭包做. 有向图的传递闭包采用Floyd思想,可以判断 ...

  3. C# inherit

    Case:class A has a construct. class B is inherit from class A and B also has a construct. What's the ...

  4. [译]Stairway to Integration Services Level 6 - SSIS 工作流管理基础

    简介 在之前的章节中,我们学习了增量载入数据. 本文中.我们通过优先约束(Precedence Constraints)来管理SSIS的工作流. 添加一个SSIS包 图 1 将新建的Package1. ...

  5. CAEmitterLayer 粒子发射器

    在iOS 5中,苹果引入了一个新的CALayer子类叫做CAEmitterLayer.CAEmitterLayer是一个高性能的粒子引擎,被用来创建实时例子动画如:烟雾,火,雨等等这些效果. CAEm ...

  6. 新技能get: 使用whois查询不明网址的信息

    1.站长之家-->Whois反查 http://whois.chinaz.com/ 进入whois.chinaz.com,输入要查询的网址,选择查询即可.

  7. NetBeans文件被锁,无法修改

    今天用NetBeans写有关Dojo的一个样例时,出现文件被锁,无法修改的情况.找了半天,但是就是不知道是什么原因,我就写在博客上记录下来

  8. Python (九) 协程以及数据库操作

    本节内容 Gevent协程 Select\Poll\Epoll异步IO与事件驱动 Python连接Mysql数据库操做 Paramiko SSH 协程 协程,又称微线程,纤程.英文名Coroutine ...

  9. {% load staticfiles %}

    原先写法 {# <link rel="stylesheet" href="/static/css/reset.css"/>#} 不使用路径写法,方便 ...

  10. WebRTC–getUserMedia & Canvas

    下面是一个使用getUserMedia接口和Canvas的drawImage方法实现的截图功能(截取视频中的一帧). 基本思路是这样子的: getUserMedia获取一个MediaStream, s ...