梦龙_C语言作业13

Posted 童话与梦

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了梦龙_C语言作业13相关的知识,希望对你有一定的参考价值。

一.简答题(共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));
}

以上是关于梦龙_C语言作业13的主要内容,如果未能解决你的问题,请参考以下文章

梦龙_C语言作业12

梦龙_C语言作业11

梦龙_C语言作业9

梦龙_C语言作业14

梦龙_C语言作业14

C语言必会面试题(3耶稣有13个门徒,当中有一个就是出卖耶稣的叛徒,请用排除法找出这位叛徒:13人围坐一圈,从第一个開始报号:1,2,3,1,2,3...。凡是报到“3”就退出圈子,...)(代码片段