一组语句在程序中多处出现,为了节省内存空间,把这些语句放在一个模块中,该模块的内聚度是( )的。
A.逻辑性
B.瞬时性
C.偶然性
D.通信性
- · 有3位网友选择 C,占比33.33%
- · 有3位网友选择 D,占比33.33%
- · 有2位网友选择 A,占比22.22%
- · 有1位网友选择 B,占比11.11%
A.逻辑性
B.瞬时性
C.偶然性
D.通信性
A.功能性
B.偶然性
C.逻辑性
D.过程性
A、时间内聚
B、步骤内聚
C、通信内聚
D、顺序内聚
A、程序员必须创建一个线程,用来释放内存
B、内存回收线程负责释放无用内存
C、内存回收线程允许程序员直接释放内存
D、内存回收线程可以在指定的时间释放内存
【说明】
本程序可以将字符串s1中出现的所有s2子串替换成s3,形成一个新串,但不破坏字符串s1。
【代码】
include<stdio.h>
include<stdlib.h>
include<string.h>
char*replace(char *s1, char *s2,char *s3)
{ char *p, *q, *r, *s; int |2,|3, i=0;
|2=strlen(s2);
|3=strlen(s3);
p=s1;
while((p=strstr(p,s2))!=NULL)
{ i++; /* 统计s2串出现的次数*/
(1);
}
i=(2);
s=r=(char*)malloc(i); /*分配动态内存存放新字符串*/
p=s1;
while(1)
{ q=strstr(p, s2); /* s2串是否在s1中出现,q是首次出现的位置*/
if(q!=NULL)
{ i=q-p;
(3);
r+=i;
(4);
r+=|3;
p=q+|2; /*将指向s1串的指针移到s2子串出现的位置后,
为下一次循环做好准备*/
}
else /*q为空,表示剩余的s1串中已经没有s2*/
{ (5);
break; /*终止循环*/
}
}
return(s); /*返回指向所形成的新串的指针*/
}
void main()
{ char *a="sabcababde", *b="ab", *c="efg", *d;
d=replace(a, b, c); printf("result=%s\n", d); free(d);
}
为了保护您的账号安全,请在“简答题”公众号进行验证,点击“官网服务”-“账号验证”后输入验证码“”完成验证,验证成功后方可继续查看答案!