Imd*_*dad 2 c arrays string pointers char
长度功能:
int length(const char s[])
{
int length = 0;
while(s[length]!='\0')
{
length++;
}
return length;
}
Run Code Online (Sandbox Code Playgroud)
插入功能:
void insert(char s1[], const char s2[], int n)
{
char *beginOfString = s1;
int lengthOfS1 = length(s1);
int lengthOfS2 = length(s2);
char s1Copy[lengthOfS1 + lengthOfS2];
int c, afterC, lengthOfRemainingPart;
c = 0;
c = n + 1;
beginOfString += c;
afterC = c; //nth position to start from to add onto array
lengthOfRemainingPart = length(beginOfString);
c = 0;
int counter = 0;
for(c = 0; c < length(s1) - 1; c++) {
s1Copy[c] = s2[counter];
for(c = afterC; c < (lengthOfS1 + lengthOfS2) - 1; c++) {
if(c == afterC) {
s1Copy[c] = s2[counter];
} else {
counter++;
if(s2[counter] != *"\0")
s1Copy[c] = s2[counter];
}
}
}
c = 0;
for(c = 0; c < length(s1Copy) - 1; c++) {
printf("\n %c \n", s1Copy[c]);
}
printf("\n");
printf("\n %s \n", beginOfString);
printf("\n %s \n", "LINE");
}
Run Code Online (Sandbox Code Playgroud)
函数调用(和相关声明):
#define MAX_STR 20
char ab[MAX_STR + 1] = "Chicken and Chips";
char b[MAX_STR + 1] = "Scampi";
insert(ab, b, 7);
Run Code Online (Sandbox Code Playgroud)
我试图将一个字符数组插入另一个字符数组,同时将其余字符保持在数组中,但根据用户想要根据 n 值插入字符数组的位置移动。
这似乎不起作用,似乎输出了错误的值。函数调用和函数头(参数类型等)需要保持原样。只有函数体本身可以改变。
输出应该是“ChickenScampi and Chips”
我哪里出错了?干杯。
不打算糖衣它。这段代码一团糟。你想要完成的任务是最简单的,如果你只是
s1[]到您的目标。s2[]到目标。s1[min(n, lengthS1)]通过s1[lengthS1]给目标。最重要的是,目标必须能够容纳两个字符串和一个nulchar终止,你的目标缓冲区没有做(这是短一个字符)。
不需要嵌套的 for 循环。无论如何,您的都已损坏,因为它正在使用自己的索引变量。
#include <stdio.h>
size_t length(const char s[])
{
const char *end = s;
while (*end)
++end;
return end - s;
}
void insert(const char s1[], const char s2[], int n)
{
size_t lengthOfS1 = length(s1);
size_t lengthOfS2 = length(s2);
size_t pos = (n < lengthOfS1) ? n : lengthOfS1;
size_t i;
// declare VLA for holding both strings + terminator
char s1Copy[lengthOfS1 + lengthOfS2 + 1];
// put in part/full s1, depending on length
for (i=0; i<pos; ++i)
s1Copy[i] = s1[i];
// append s2
for (i=0; i<lengthOfS2; ++i)
s1Copy[pos+i] = s2[i];
// finish s1 if needed.
for (i=pos; i<lengthOfS1; ++i)
s1Copy[i+lengthOfS2] = s1[i];
// termiante string
s1Copy[lengthOfS1 + lengthOfS2] = 0;
puts(s1Copy);
}
int main()
{
char ab[] = "Chicken and Chips";
char b[] = "Scampi";
insert(ab, b, 0);
insert(ab, b, 7);
insert(ab, b, 100);
}
Run Code Online (Sandbox Code Playgroud)
输出
#include <stdio.h>
size_t length(const char s[])
{
const char *end = s;
while (*end)
++end;
return end - s;
}
void insert(const char s1[], const char s2[], int n)
{
size_t lengthOfS1 = length(s1);
size_t lengthOfS2 = length(s2);
size_t pos = (n < lengthOfS1) ? n : lengthOfS1;
size_t i;
// declare VLA for holding both strings + terminator
char s1Copy[lengthOfS1 + lengthOfS2 + 1];
// put in part/full s1, depending on length
for (i=0; i<pos; ++i)
s1Copy[i] = s1[i];
// append s2
for (i=0; i<lengthOfS2; ++i)
s1Copy[pos+i] = s2[i];
// finish s1 if needed.
for (i=pos; i<lengthOfS1; ++i)
s1Copy[i+lengthOfS2] = s1[i];
// termiante string
s1Copy[lengthOfS1 + lengthOfS2] = 0;
puts(s1Copy);
}
int main()
{
char ab[] = "Chicken and Chips";
char b[] = "Scampi";
insert(ab, b, 0);
insert(ab, b, 7);
insert(ab, b, 100);
}
Run Code Online (Sandbox Code Playgroud)
概括
如果您不确定发生了什么,那么您应该做的最后一件事就是编写更多代码。相反,停止编码,拿些纸和书写工具,然后重新思考问题。
| 归档时间: |
|
| 查看次数: |
2415 次 |
| 最近记录: |