diff --git a/libft.h b/libft.h index c904365..e01ccd0 100644 --- a/libft.h +++ b/libft.h @@ -45,7 +45,7 @@ char *ft_substr(char const *s, unsigned int start, size_t len); char *ft_strjoin(char const *s1, char const *s2); char *ft_strtrim(char const *s1, char const *set); char **ft_split(char const *s, char c); -char *ft_itoa(int n); +char *ft_itoa(long int n); char *ft_strmapi(char const *s, char (*f)(unsigned int, char)); void ft_putchar_fd(char c, int fd); void ft_putstr_fd(char *s, int fd); diff --git a/srcs/ft_itoa.c b/srcs/ft_itoa.c index 2301491..d36201a 100644 --- a/srcs/ft_itoa.c +++ b/srcs/ft_itoa.c @@ -15,9 +15,10 @@ */ /* -** #include +** #include // for printf +** #include // for atoi ** -** char *ft_itoa(int n); +** char *ft_itoa(long int n); ** ** int main(int ac, char **av) ** { @@ -26,32 +27,65 @@ ** else if (ac == 2) ** printf("%s\n",ft_itoa(atoi(av[1]))); ** else -** printf("%s\n",ft_itoa(0)); +** { +** long int i; +** i = 0; +** printf(" %li\n %s\n\n",i,ft_itoa(i)); +** i = 1234567; +** printf(" %li\n %s\n\n",i,ft_itoa(i)); +** i = -1234567; +** printf(" %li\n %s\n\n",i,ft_itoa(i)); +** i = 237683; +** printf(" %li\n %s\n\n",i,ft_itoa(i)); +** i = 2147483647; +** printf("| %li\n| %s\n\n",i,ft_itoa(i)); +** i = i ^ 0; // create the opposite of a signed '0', which +** // is 0 followed by 31 '1', the signed int max +** printf("* %li\n* %s\n\n",i,ft_itoa(i)); +** i = i ^ 0; +** i = 1 << 31; // change the most lefted bit from '0' (positive) +** // to '1' (negative), the signed int min +** printf("* %li\n* %s\n\n",i,ft_itoa(i)); +** i = 2147483646; +** printf(" %li\n %s\n\n",i,ft_itoa(i)); +** i = -2147483648; +** printf("| %li\n| %s\n\n",i,ft_itoa(i)); +** i = -2147483647; +** printf(" %li\n %s\n\n",i,ft_itoa(i)); +** i = 2147483648; +** printf(" %li\n %s\n\n",i,ft_itoa(i)); +** i = -2147483649; +** printf(" %li\n %s\n\n",i,ft_itoa(i)); +** i = 9223372036854775807; +** printf("| %li\n| %s\n\n",i,ft_itoa(i)); +** i = -9223372036854775807; +** printf("| %li\n| %s\n\n",i,ft_itoa(i)); +** } ** return 0; ** } */ #include "libft.h" -char *ft_itoa(int n) +char *ft_itoa(long int n) { char *str; int len; - long int nbis; + long int cpy; + char rgt; + cpy = (n < 0) ? (n / 10) * -10 : (n / 10) * 10; len = (n < 0) ? 2 : 1; - nbis = n; - while (nbis /= 10) + rgt = (n < 0) ? (n % 10) * -1 + '0' : n % 10 + '0'; + while (n /= 10) len++; - nbis = n; - nbis *= (nbis < 0) ? -1 : 1; if (!(str = (char *)malloc(sizeof(char) * (len + 1)))) return (NULL); str[len] = '\0'; - str[--len] = nbis % 10 + '0'; - while (nbis /= 10) - str[--len] = nbis % 10 + '0'; - if (n < 0) + str[--len] = rgt; + while (cpy /= 10) + str[--len] = cpy % 10 + '0'; + if (len) str[0] = '-'; return (str); }