0
0
This commit is contained in:
Guy Baconniere
2021-08-20 10:02:48 +02:00
parent d30270c485
commit 7da4868c86
3 changed files with 52 additions and 20 deletions

Binary file not shown.

View File

@@ -6,7 +6,7 @@
/* By: gbaconni <gbaconni@42lausanne.ch> +#+ +:+ +#+ */ /* By: gbaconni <gbaconni@42lausanne.ch> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2021/08/19 11:25:51 by gbaconni #+# #+# */ /* Created: 2021/08/19 11:25:51 by gbaconni #+# #+# */
/* Updated: 2021/08/19 17:54:51 by gbaconni ### ########.fr */ /* Updated: 2021/08/20 09:52:49 by gbaconni ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@@ -19,8 +19,40 @@ static int ft_strlen(char *str)
int len; int len;
len = 0; len = 0;
while (str[len++] != '\0') while (str[len] != '\0')
continue ; len++;
return (len);
}
char *ft_strcat(char *dest, char *src)
{
char *s1;
char *s2;
s1 = dest;
s2 = src;
while (*s1 != '\0')
s1++;
while (*s2 != '\0')
*s1++ = *s2++;
*s1 = '\0';
return (dest);
}
int ft_strslen(int size, char **strs, char *sep)
{
int len;
int i;
len = 1;
i = 0;
while (i < size)
{
len += ft_strlen(strs[i]);
if (i < size - 1)
len += ft_strlen(sep);
i++;
}
return (len); return (len);
} }
@@ -30,20 +62,18 @@ char *ft_strjoin(int size, char **strs, char *sep)
int len; int len;
int i; int i;
len = 0; if (strs == NULL)
len = strlen(sep); return (NULL);
printf("strlen %d", len); len = ft_strslen(size, strs, sep);
len = 0; str = (char *) malloc(len * sizeof(char));
len = ft_strlen(sep);
printf("ft_strlen %d", len);
len = 0;
i = 0; i = 0;
while (i < size) while (i < size)
{ {
len += ft_strlen(strs[i]) - 1; ft_strcat(str, strs[i]);
len += ft_strlen(sep) - 1; if (i < size - 1)
ft_strcat(str, sep);
i++;
} }
printf("len=%d\n", len); strs[i] = "\0";
str = (char *) malloc(len * sizeof(char));
return (str); return (str);
} }

View File

@@ -5,8 +5,8 @@
/* +:+ +:+ +:+ */ /* +:+ +:+ +:+ */
/* By: gbaconni <gbaconni@42lausanne.ch> +#+ +:+ +#+ */ /* By: gbaconni <gbaconni@42lausanne.ch> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2021/08/19 11:11:01 by gbaconni #+# #+# */ /* Created: 2021/08/20 09:34:53 by gbaconni #+# #+# */
/* Updated: 2021/08/19 18:28:17 by gbaconni ### ########.fr */ /* Updated: 2021/08/20 09:36:09 by gbaconni ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@@ -25,16 +25,18 @@ int main(void)
char *result; char *result;
sep = ""; sep = "";
strs = malloc(3 * sizeof(strs)); strs = malloc(3 * sizeof(*strs));
sep = (char *) malloc(32 * sizeof(char));
i = 0; i = 0;
while (i < 3) while (i < 3)
{ {
printf("Input String #%d: ", i + 1); strs[i] = (char *) malloc(32 * sizeof(char));
scanf("%s", strs++); printf("Input String #%d [Max 31]: ", i + 1);
scanf("%s", strs[i++]);
} }
printf("Input Separator: "); printf("Input Separator: ");
scanf("%s", sep); scanf("%s", sep);
result = ft_strjoin(i, strs, sep); result = ft_strjoin(i, strs, sep);
printf("result=%s sep=%s (ft_strjoin)\nresult:\n", result, sep); printf("size=%d sep=%s result=%s (ft_strjoin)\n", i, sep, result);
return (0); return (0);
} }