#include #include #include #define MAXLEN 50 void itoa(int n, char s[]); void reverse(char s[]); /* fixes itoa function to handle the largest negative number */ int main(int argc, char *argv[]) { char s[MAXLEN]; itoa(INT_MIN, s); printf("Largest negative number on machine: %d\n", INT_MIN); printf("Largest negative number after itoa: %s\n", s); return 0; } void itoa(int n, char s[]) { int i, sign; i = 0; sign = n < 0; if (!sign) { do { s[i++] = n % 10 + '0'; } while ((n /= 10) > 0); } else { // avoid integer overflow of n = -n for min integer in original impl // by handling negtive values separately. do { s[i++] = -(n % 10) + '0'; } while ((n /= 10) <= -1); } if (sign) s[i++] = '-'; s[i] = 0; reverse(s); } void reverse(char s[]) { int c, i, j; for (i = 0, j = strlen(s) - 1; i < j; i++, j--) { c = s[i]; s[i] = s[j]; s[j] = c; } }