练习 3-6
修改 itoa 函数,使得该函数可以接收三个参数。其中,第三个参数为最小
字段宽度。为了保证转换后所得的结果至少具有第三个参数指定的最小宽度,在必要时应在
所得结果的左边填充一定的空格。
加的代码不多,其实想清楚了就是两个循环
x是传进来的指定宽度
i是字符串s中‘\0’的下标
x--; //指定宽度的最后一位下标
if (i < x)
{
//先将数据后移
while (i >=0)
s[x--] = s[i--];
//再补空格
while (x >= 0)
s[x--] = ' ';
其实可以变成一个循环,但感觉2个循环比较清晰
完整函数 :
void itoa(int n, char s[], int x)
{
int sign, i;
sign = n;
i = 0;
do {
if (sign < 0)
s[i++] = -(n % 10) + '0';
else
s[i++] = n % 10 + '0';
} while ((n /= 10) != 0);
if (sign < 0)
s[i++] = '-';
s[i] = '\0';
reverse(s);
//-----------------------------------
x--; //指定宽度的最后一位下标
if (i < x)
{
//先将数据后移
while (i >=0)
s[x--] = s[i--];
//再补空格
while (x >= 0)
s[x--] = ' ';
}
}
完整代码 :
/*练习 3-6 修改 itoa 函数,使得该函数可以接收三个参数。其中,第三个参数为最小
字段宽度。为了保证转换后所得的结果至少具有第三个参数指定的最小宽度,在必要时应在
所得结果的左边填充一定的空格。
*/
#include <stdio.h>
void itoa(int n, char s[], int x);
void reverse(char s[]);
main()
{
int n, x;
n = (~0U >> 1) + 1; //int 最小值
x = 20;
char s[1024];
itoa(n, s, x);
printf("%s\n", s);
}
void itoa(int n, char s[], int x)
{
int sign, i;
sign = n;
i = 0;
do {
if (sign < 0)
s[i++] = -(n % 10) + '0';
else
s[i++] = n % 10 + '0';
} while ((n /= 10) != 0);
if (sign < 0)
s[i++] = '-';
s[i] = '\0';
reverse(s);
//-----------------------------------
x--; //指定宽度的最后一位下标
if (i < x)
{
//先将数据后移
while (i >=0)
s[x--] = s[i--];
//再补空格
while (x >= 0)
s[x--] = ' ';
}
}
void reverse(char s[])
{
int i, j, c;
for (j = 0; s[j] != '\0'; j++)
;
for (i = 0, j--; i < j; i++, j--)
{
c = s[i];
s[i] = s[j];
s[j] = c;
}
}