溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

打印 1 到最大的 n 位數(shù)

發(fā)布時間:2020-07-06 09:45:52 來源:網(wǎng)絡 閱讀:637 作者:duanjiatao 欄目:編程語言

題目描述: 輸入數(shù)字 n ,按順序打印出從 1 最大的 n 位十進制數(shù)。

例如:輸入 3,則打印出 1、2、3……一直到最大的 3 位數(shù)即 999。


分析:

打印 1 到最大的 n 位數(shù)

void Print1ToMaxOfNDigits(int n)
{
    iunt number = 1;
    int i = 0;
    while(i++ < n)
    number *= 10;
    
    for(i = 1; i < number; ++i)
        printf("%d\t", i);
        
}

打印 1 到最大的 n 位數(shù)

在字符串上模擬數(shù)字的加法

打印 1 到最大的 n 位數(shù)

打印 1 到最大的 n 位數(shù)

void Print1ToMaxOfNDigits(int n)
{
    if(n <= 0)
        return;
 
    char *number = new char[n + 1];
    memset(number, '0', n);
    number[n] = '\0';
 
    while(!Increment(number))
    {
        PrintNumber(number);
    }
 
    delete []number;
}

打印 1 到最大的 n 位數(shù)

// 字符串number表示一個數(shù)字,在 number上增加1
// 如果做加法溢出,則返回true;否則為false
bool Increment(char* number)
{
    bool isOverflow = false;
    int nTakeOver = 0;
    int nLength = strlen(number);
 
    for(int i = nLength - 1; i >= 0; i --)
    {
        int nSum = number[i] - '0' + nTakeOver;
        if(i == nLength - 1)
            nSum ++;
 
        if(nSum >= 10)
        {
            if(i == 0)
                isOverflow = true;
            else
            {
                nSum -= 10;
                nTakeOver = 1;
                number[i] = '0' + nSum;
            }
        }
        else
        {
            number[i] = '0' + nSum;
            break;
        }
    }
 
    return isOverflow;
}

打印 1 到最大的 n 位數(shù)

void PrintNumber(char* number)
{
    bool isBeginning0 = true;
    int nLength = strlen(number);
 
    for(int i = 0; i < nLength; ++ i)
    {
        if(isBeginning0 && number[i] != '0')
            isBeginning0 = false;
 
        if(!isBeginning0)
        {
            printf("%c", number[i]);
        }
    }
 
    printf("\t");
}

打印 1 到最大的 n 位數(shù)打印 1 到最大的 n 位數(shù)打印 1 到最大的 n 位數(shù)打印 1 到最大的 n 位數(shù)打印 1 到最大的 n 位數(shù)打印 1 到最大的 n 位數(shù)打印 1 到最大的 n 位數(shù)打印 1 到最大的 n 位數(shù)打印 1 到最大的 n 位數(shù)打印 1 到最大的 n 位數(shù)打印 1 到最大的 n 位數(shù)打印 1 到最大的 n 位數(shù)打印 1 到最大的 n 位數(shù)

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI