日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

计算数字的出现次数 java_关于Java:如何计算数字在.txt文件中出现的次数

發布時間:2023/12/4 java 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 计算数字的出现次数 java_关于Java:如何计算数字在.txt文件中出现的次数 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

早上好,

我正在做一些Java練習,偶然發現了這個問題。 我有一個.txt文件,其中包含多個數字,每行一個。 練習的目的是查看哪些數字等于10 ^ 0,...,10 ^ n直到達到n。 然后,我必須在.txt中寫入每個數字出現多少次。

所以我有一個文件:

1個

100

100

100

10

1個

1個

我需要寫:

1-10

3-1

3-100

我可以讀取文件,然后檢查編號并打印。 我只是想不通如何正確地做一個計數器。 有什么幫助嗎?

這是一段代碼:

// TODO - Count how many time a number appears.

public static void numberOfTimes (BufferedReader in, BufferedWriter out, int n) ? ? ? ?throws IOException {

String s;

int i;

int counter = 0;

while ((s = in.readLine()) != null) {

i = Integer.parseInt(s);

for (int j = 0; j <= n; j++) {

if (i == Math.pow(10, j)) {

counter++;

out.write(Integer.toString(counter) +"" + Integer.toString(i) +"

");

}

}

}

}

所以您只需要計算1、10、100、1000等數字? 換句話說,源文件中可以有數字45嗎?

是的,源文件中混合了很多數字。 我只需要給定某個n,然后檢查所有這些,看看哪些是10 ^ 0到10 ^ n并計數。

由于要跟蹤多個計數,因此單個整數計數器顯然不夠用。

一種可能性是使用Map進行計數。 因為這是家庭作業,所以我留給您找出細節。

另一種可能性是使用一個計數數組,并使用log10(i)作為該數組的索引。 換句話說,10^k的計數將存儲在數組的第k個位置。 提示:在您的代碼中,您已經在間接計算log10(i)。

log10創意為+1,這在特定情況下適用,但不適用于任何數字(與映射始終有效的地圖不同)。

或者您可以只使用字符串長度-1(=零個數)

嗡嗡聲,從未使用過或聽說過$ Map ,但我將介紹一下API。

我當時是這樣想的:將所有找到的值存儲在一個數組中,然后針對每個數組查找數組。 如果發現例如3 10 ^ 0,則counter1 = 3,counter1 = 2,依此類推2,等等。但這看起來效率很低,我希望有一個更簡潔,更簡短的解決方案。 感謝您的所有答復。

由于您正在處理Integer,因此可以預加載所有小于Integer.MAX(2,147,483,647)的值的Map。

映射將需要10 ^ 0,10 ^ 1,...,10 ^ 9中的所有值作為鍵(總共十(10)個鍵)。 然后,您需要對讀取的值進行布爾檢查,如果與這些鍵之一匹配,則將該鍵的值加1。

總結

以上是生活随笔為你收集整理的计算数字的出现次数 java_关于Java:如何计算数字在.txt文件中出现的次数的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。