12.23练习题

1、改错:
(a)、void test1()
{
char string[10];
char *str1 = “0123456789”;
strcpy(string, str1);
}

字符串复制超过了这个字符串大小。因为这个字符串之后有一个结束符。字符串复制之后会因为函数的结束而被释放。
(b)、void test2()
{
char string[10], str1[10];
for (i=0; i<10; i++)
{
str1[i] = ‘A’;
}
strcpy(string, str1);
}
字符串之后有一个结束标志,而这个没有结束标志,所以错误。字符串复制之后会因为函数的结束而被释放。
(c)、void test3(char *str)
{
char string[10];
if (strlen(str1)<=10)
{
strcpy(string, str1);
}
}
没有字符串的大小,且字符串复制之后会因为函数的结束而被释放。
2、找赛手:2个羽毛球队比赛,各出3人,每个人只比一次。甲队为A,B,C三人,乙队为X,Y,Z三人。有人打听比赛名单,A说他不和X比,C说不和X,Z比。编程找出三队赛手的名单.

#include <stdio.h>
 int main(void)
{
    int i = 0;
    int j = 0;
    for (i='a'; i<'d'; i++)
    {
        for (j='x'; j<='z'; j++)
        {
            if((i=='a' && j== 'x')  ||  (i=='c' && (j=='x' || j=='z')))
                ;//符合题意的话什么都不做。
            else
                printf("%c and %c.\n", i, j);
        }
    }
    return 0;
}
/*
a and y.
a and z.
b and x.
b and y.
b and z.
c and y.
*/

3、用C语言实现字符串中子字符串的替换, 成功返回0,失败返回-1.例如:“ABCDEFG”这个字符串,把其中”BCD”替换成“9527”这个子串,结果变成:“A9527EFG”
函数原型:
int str_replace(char str, char replaced_str, char *new_str)


#include <stdio.h>
#include <string.h>
int replace(char *replaced_str, char *new_str, int len)
{
    int i = 0, j = 0, q = 0;

            //  printf("ok\n");
    q =  len - strlen(new_str);
    if (0 == q)                                                     //新字符串与被替换字符串等长 
    {
        for (i=0; i<strlen(new_str); i++)
        {
            replaced_str[i] = new_str[i];
        }
    }
    else if (q > 0)                                                 //新字符串更短 
    {
        for (i=0; i<strlen(new_str); i++)
        {
            replaced_str[i] = new_str[i];
        }
        for (i; replaced_str[i+q]; i++)
        {
            replaced_str[i] = replaced_str[i+q];
        }
        replaced_str[i] = 0;
    }
    else                                                            //新字符串更长
    {
    //  printf("ok\n");
        char  *p = replaced_str;
        //printf("ok\n");
        int len = strlen(replaced_str);
        replaced_str += strlen(replaced_str);
        replaced_str--;
        printf("%c\n", *replaced_str);
    //  while(++replaced_str);
        replaced_str = replaced_str - q;  //q是负的 
        int w = 0;
        printf("%c\n", *replaced_str);     // 
        while(w < len)
        {
            *replaced_str = *(replaced_str - q);      ///
            replaced_str -= 1;
            w++;
        }
        //printf("ok\n");
        for (i=0; i<strlen(new_str); i++)
        {
            printf ("%c = ", *(p+i));
            *(p+i)= new_str[i];
            printf ("%c\n", (*p)); 
        } 
        //printf("ok\n");
    }
    return 1;
}
int str_replace(char *str, char * replaced_str, char *new_str) 
{
    int i = 0, j = 0, len = strlen(replaced_str), q = 0;
//  int *p = (int *)malloc(strlen(str)/len);
//  printf("%d\n", len);
    for (i=0; str[i]; i++)
    {
        if (str[i] == replaced_str[0])
        {
            for (j=0; j<len; j++)
            {
                if (str[i+j] != replaced_str[j])
                {
                    break;
                }
            }
            if (j == len)
            {
            //  printf("ok\n");
                printf("%c\n", str[i]);
                q = replace(&str[i], new_str, len);
            }
        //  printf("ok\n");  no
        }
    }
//  printf("%d\n", i);
    return q;
}
int main(void)
{
    char s[20] = "ABCDEFG";
    if(str_replace(s,"BCD","9527"))
        printf("%s.\n", s);
    else
        printf("失败.\n");
    return 0;
}

不会了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值