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;
}
不会了