面試題32 從1到n整數中1出現的次數

2022-07-27 11:36:12 字數 536 閱讀 6891

【題目描述】

輸入乙個整數n,求從1到n這個整數的十進位制表示中1出現的次數。

例如,輸入12,從1到12這些整數中包含1的數字有1,10,11和12,1一共出現了5次。

【解決方案】

解法一:不考慮時間複雜度

我的**實現,僅供參考:

1

public

static

int numofonefromoneton(intn)2

14}1516

return

result;

17 }

解法二:從數字規律著手明顯提高時間效率的解法

我的**實現,僅供參考:

1

public

static

int numberof1between1andn(intn)2

1011

public

static

int numberof1(string

str)

12

面試題32 從1到n整數中1出現的次數

題目 輸入乙個整數n,求從1到n這n個整數的十進位制表示中1出現的次數。例如輸入12,從1到12這些整數中包含1的數字有1,10,11和12共4次。1,不考慮時間效率的方法,每瀏覽乙個數,判斷每一位是不是含1.時間複雜度 位數o logn 數n,總 o n logn 2,根據數學規律 排列組合 對1...

面試題32 從1到n整數中1出現的次數

include include include using namespace std int powerofn int n return result int numberofone const char str int len strlen str int first str 0 if 1 le...

整數中1出現的次數(從1到n整數中1出現的次數)

求出1 13的整數中1出現的次數,並算出100 1300的整數中1出現的次數?為此他特別數了一下1 13中包含1的數字有1 10 11 12 13因此共出現6次,但是對於後面問題他就沒轍了。acmer希望你們幫幫他,並把問題更加普遍化,可以很快的求出任意非負整數區間中1出現的次數。include u...