#include<stdio.h>
int myStrLen(char *s);
void myStrConcat(char *string1, char *string2);
int main()
{
int n, i, a, b, c[10];
char s[10][41];
scanf("%d %d %d", &n, &a, &b);
for (i = 0; i < n; i++)
scanf("%d", &c[i]);
for (i = 0; i < n; i++)
scanf("%s", s[i]);
myStrConcat(s[a], s[b]);
for (i = 0; i < n; i++)
{
printf("%d", myStrLen(s[i]));
if (s[i + 1])
printf(" ");
}
printf("\n");
for (i = 0; i < n; i++)
{
printf("%s", s[c[i]]);
if (i < n - 1)
printf("\n");
}
return 0;
}
int myStrLen(char *s)
{
int i;
for (i = 0; s[i]; i++)
{ }
return i;
}
void myStrConcat(char *string1, char *string2)
{
int i = 0, j = 0;
while (string1[i] != '\0')
i++;
while (string2[j] != '\0')
string1[i++] = string2[j++];
string1[i] = '\0';
}
(c语言的)为什么oj平台一直显示运行时错误?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- 502203305 2019-05-11 21:07关注
错误原因myStrConCat函数,两个字符串拼接,当两个字符串特别长的时候,就需要动态分配内存来完成。
即char *str_after_concat=(char*)malloc ( sizeof(char) * (myStrLen(string1)+mystrLen(string2)+1));
这里的+1是因为我们将要返回一个C风格的字符串,
即字符串末尾以\0结尾。
那么至于你的myStrLen的for函数,可以换成for (i = 0; s[i]; i++);
这种看着很简洁。也可以不用这种方法,有很多不做举例。
那么上面进行新建了函数,那么后面的逻辑就差不多正确了,只需要将string1换成前面我的代码所创建的变量str_after_concat
然后并且将这个指针返回并输出(因为malloc是在堆中动态分配,不会像局部变量一样回收。)解决 2无用
悬赏问题
- ¥15 c程序不知道为什么得不到结果
- ¥40 复杂的限制性的商函数处理
- ¥15 程序不包含适用于入口点的静态Main方法
- ¥15 素材场景中光线烘焙后灯光失效
- ¥15 请教一下各位,为什么我这个没有实现模拟点击
- ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
- ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
- ¥20 有关区间dp的问题求解
- ¥15 多电路系统共用电源的串扰问题
- ¥15 slam rangenet++配置