正如’jamesdlin’在他的评论中提到的那样,GMan的方法会起作用,但是你需要将它存储在一个缓冲区中才能以正确的顺序打印出来(他的算法会输出“6 5 4 3 2 1”进行输入123456).在这一点上,我会说,在他的回答中建议使用sprintf作为’wherehere’会更简单(如果这不是算法类的分配).
在我看来,最简单的方法是使用递归,这样你就可以在不使用缓冲区的情况下以正确的顺序打印出数字.
递归实现非常简单:
void PrintfRecursivly(int number)
{
if (number < 0)
{
number *= -1;
printf("- ");
}
if (number > 10)
{
PrintfRecursivly(number / 10);
printf(" ");
}
printf("%d", number % 10);
}
int main()
{
int number = -78900456;
PrintfRecursivly(number);
return 0;
}
输入:
-78900456
输出:
06001
编辑:感谢史蒂夫杰索普,当我离开时,他提出了正整数的正确算法.我更改了上面的方法,以正确打印所有整数(正面和负面),没有最后一个空格.
请注意,我们可以避免在每次递归中检查负值,只需检查一次(在主函数或任何地方),但我没有写它,因为我们在清晰度上会比性能增益损失更多.