一.简答题(共1题,5.0分)
1
13-1 编写一个函数char *compact(char s[]);,以一个字符串s作为参数,能将字符串中重复出现的字母删除并返回该字符串的首地址。主程序从键盘输入一个字符串,调用该函数处理该字符串后显示结果。(判断重复字母不区分大小写,不要有任何提示文字)
例如:输入:To be or not to be,that’s a question
显示的结果为:To be r n ,ha’s qui
#include <stdio.h>
#include <string.h>
#define MAX 100
char *compact(char s[]);
int main()
{
char s[MAX];
gets(s);
char *str=compact(s);
puts(str);
return 0;
}
char *compact(char s[])
{
int i,j,k;
int len=strlen(s);
for(i = 0; i <= len - 1; i ++)
{
if((s[i]<='z'&&s[i]>='a')||(s[i]<='Z'&&s[i]>='A'))
for(j = i + 1; j <= len - 1; j ++)
{
if((s[i] == s[j])||((s[i]+32)==s[j])||((s[i]-32)==s[j]))
{
for(k = j; k <= len - 1; k ++)
{
s[k]=s[k + 1];
}
len --;
j --;
}
}
}
s[len] = '\0';
return s;
}
二.程序题(共2题,10.0分)
1
5.12 请编写一个函数lendiff,以两个字符串为参数,返回第1个参数的串长与第2个参数的串长的差。利用该函数,编写主程序,从键盘输入两个串,然后显示串长差。(结果不要提示文字和回车)
例如,输入abcde abcd,显示1
#include <stdio.h>
#include <string.h>
int lendiff(char* s1,char* s2)
{
return (strlen(s1) - strlen(s2));
}
void main()
{
char s1[100],s2[100];
scanf("%s %s",s1,s2);
printf("%d",lendiff(s1,s2));
}
2
5.15 请编写一程序,先输入1个字符串作为母串,再输入1个字符串作为子串,要允许字符串中包含空格,然后不区分字母大小写统计母串中出现子串的个数并显示结果,例如:输入This is a television set.作为母串,再输入IS作为子串,会显示结果3。(不要有提示文字,结果不要回车, 使用string.h库)
#include <stdio.h>
#include <string.h>
int strfun(char* str,char* substr)
{
int count = 0;
char* p = strstr(str,substr);
while(p!=NULL)
{
count++;
p=strstr(p+strlen(substr),substr);
}
return count;
}
void main()
{
char str[100],substr[100];
strlwr(gets(str));
strlwr(gets(substr));
printf("%d",strfun(str,substr));
}