只使用處理I/O的PrintDigit函數,編寫一個過程以輸出任意實數


#include <stdio.h>
#include <stdlib.h>
#include <math.h>
int printDigit(int a)
{
    printf("%d",a);
}
void printInt(int N)
{
    if(N>=10)
      printInt(N/10);
    printDigit(N-(int)(N/10)*10);
}
void printOut(double N,int accuracy)
{
    if(N<0)
    {
        putchar('-');
        N=-N;
    }
    int n=(int)N;
    printInt(n);
    double decimal=N-n;
    if(decimal>0)
    {
        putchar('.');
     double add=0.5;
    for(int i=0;i<accuracy;i++)
    {
        add/=10;
    }
    N+=add;
    for(int i=0;i<accuracy;i++)
    {
        decimal*=10;
    }
    printInt(decimal);
   }
}
int main()
{
    printOut(1263.15087,3);
    return 0;
}
View Code

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM