H面试程序(28):字符串处理转换
//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):字符串处理转换的更多相关文章
- H面试程序(27):字串转换
//1 字串转换 //问题描述: //将输入的字符串(字符串仅包含小写字母‘a’到‘z’),按照如下规则,循环转换后输出:a->b,b->c,…,y->z,z->a: //若输 ...
- H面试程序(10): 字符串包含问题
题目描述:判断第二个字符串中的元素是否都能在第一个字符串中找到: 注意:和字符串的字串的问题有所区别,如第一个字符串为 abcdefg,第二个字符串为 aaabc,第二个字串还是包含于第一个字符串 ...
- H面试程序(11): 判断字符串是否包含子串问题
题目描述: 如字符串str1为''abcdef''' 字符串str2为'' bc''; 则字符串str1中含有 ...
- H面试程序(12): 输出字符串中第一个只出现一次的字母
题目描述: 若字符串str为'' sbdddsbfc'',则输出 f; 若字符串str为''aabbccdd'',则输出:字符串str中的字符都出现两次以上 #include <stdio.h& ...
- H面试程序(4):翻转句子中单词的顺序 .
题目:输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变. 句子中单词以空格符隔开.为简单起见,标点符号和普通字母一样处理. 例如输入“I am a student.”,则输出“stude ...
- H面试程序(1)编写一个函数,要求输入年月日时分秒,输出该年月日时分秒的 下一秒
编写一个函数,要求输入年月日时分秒,输出该年月日时分秒的下一秒. 如输入 2004 年 12 月 31 日 23 时 59 分 59 秒,则输出 2005年 1 月 1 日 0 时 0 分 0 秒. ...
- H面试程序(29):求最大递增数
要求:求最大递增数 如:1231123451 输出12345 #include<stdio.h> #include<assert.h> void find(char *s) { ...
- H面试程序(15): 冒泡排序法
#include<stdio.h> #include<assert.h> void display(int * a, int n) { for(int i = 0; i < ...
- H面试程序(16): 简单选择排序
#include<stdio.h> #include<assert.h> void display(int * a, int n) { assert(a); for(int i ...
随机推荐
- SQL Server(SSIS package) call .net DLL
There are two method to call .net DLL in SQLSERVER. The first one is to use the sql clr but it has a ...
- input autocomplete 下拉提示+支持中文
js 代码: $.getJSON("/Foreign/Getforeign_routeEndPoint", function (data) { $(" ...
- Oracle游标-循环查询表中数据(表名),并执行
Oralce 表中存有一个字段,该字段存储表名,要把该表中的所有表名查询出来(即表名结果集),且执行结果集from 表名结果集: declare v_ccount ); --定义一个游标变量 curs ...
- UI界面
http://www.uimaker.com/uimakerhtml/uidesign/uisoft/2016/0323/122862.html http://www.uimaker.com/uima ...
- ecplise启动tomcat异常
由于myeclipse为正常关闭,导致下次启动时抛出异常:类似于无法加载异常缓存的内容之类... 处理办法: 1.关闭myeclipse 2.找到工作空间/.metadata/.plugins/ 3. ...
- ClassLoader简单介绍
要理解ClassLoader,我们可以通过what.how两个方面来解释 一.what:什么事ClassLoader? 1.ClassLoader可以是将class文件加载到JVM方法区. 2.Cla ...
- Main function
Main function A program shall contain a global function named main, which is the designated start of ...
- BZOJ 1660: [Usaco2006 Nov]Bad Hair Day 乱发节( 单调栈 )
维护一个h严格递减的栈 , 出栈时计算一下就好了.. ------------------------------------------------------------------------- ...
- 运用Python语言编写获取Linux基本系统信息(二):文件系统使用情况获取
本文跟着上一篇文章继续写,上一篇文章的链接 运用Python语言编写获取Linux基本系统信息(一):获得Linux版本.内核.当前时间 一.随便说说 获取文件系统使用情况的思路和上一篇获取主要系统是 ...
- HLS 协议
HTML 5 视频直播一站式扫盲 本文来自于腾讯bugly开发者社区,原文地址:http://bugly.qq.com/bbs/forum.php?mod=viewthread&tid=1 ...