求取眾數及重數的演算法實現(Java)
求取眾數及重數的演算法實現(Java)
– 給定含有n個元素的多重集合S,每個元素在S中出現
的次數稱為該元素的重數。
– 多重集S中重數最大的元素稱為眾數。
– 例如,S={1,2,2,2,3,5}。多重集S的眾數是2,其重數
為3。
– 對於給定的n個自然陣列成的多重集S,計算S的眾數
及其重數 。
/*作者:李泯
* UCAS
* 自然數序列重數及眾數的求取演算法實現
* 2018/10/13
*/
import java.util.Arrays;
public class ModeDemo {
public static void main(String[] args) {
//int[] ary = {1,2,2,2,3,5};//作業題目
int[] ary = {1,5,8,2,1,4,7,4,2,5,9,6,3,2,1,4,7,8,5,5,8,8,5,8};
int[] a = ary2num(ary);
System.out.println("原始自然數序列為:" + Arrays.toString(ary));
System.out.println("自然數種類為:" + Arrays.toString(a));
System.out.println("各類別重數為:" + Arrays.toString(count(ary,a)));
System.out.println("眾數及其重數為:" + a[findmax(count(ary,a))] + ";" + count(ary,a)[findmax(count(ary,a))]);
}
//ary2num:實現由若干個個自然數的集合到其中所含自然數種類集合的方法(去除重複出現的自然數)。
static int[] ary2num(int[] ary){
int[] num_1 = new int[ary.length];
int n =0;
int yes = 0;//yes為0時,表示之前尚未出現該自然數,錄入num_1
for(int i = 0;i < ary.length;i++) {
for (int j = 0; j < num_1.length; j++) {
if (ary[i] == num_1[j]){
yes = 1;
break;
}
}
if(yes == 0) {
num_1[n] = ary[i];
n++;
}
yes = 0;
}
//System.out.println(n);
//去掉num_1陣列中的0
int[] num = new int[n];
for(int i = 0;i < n;i++) {
num[i] = num_1[i];
}
return num;
}
//對num陣列中的各個自然數的重數做統計
static int[] count(int[] array,int[] num) {
int[] count = new int[num.length];
for (int i = 0; i < num.length; i++) {
for (int j = 0; j < array.length; j++) {
if(array[j] == num[i]) {
count[i]++;
}
}
}
return count;
}
//尋找count中的最大值,返回最大值索引
static int findmax(int[] array) {
int max_index = 0;
for (int i = 0; i < array.length-1; i++) {
if (array[i+1] > array[i]) {
max_index = i+1;
}
}
return max_index;
}
}
相關文章
- c++實現求眾數及其重數C++
- 演算法設計--眾數和重數問題(分治法)演算法
- 一次數獨生成及解題演算法的剖析(Java實現)演算法Java
- 找眾數演算法演算法
- 演算法題:求眾數演算法
- 優化的求眾數方法 - 摩爾投票演算法(演算法思想+求眾數的三種方法+摩爾投票演算法改進版求眾數 II)優化演算法
- 【演算法】已知必存在眾數,求該眾數 -- Boyer-Moore 投票演算法演算法
- RSA加密解密及數字簽名Java實現加密解密Java
- [PHP] 演算法-陣列重複數字統計的PHP實現PHP演算法陣列
- 權重隨機演算法的java實現隨機演算法Java
- 【演算法】求眾數-js解法演算法JS
- 演算法:Majority Element(求眾數)演算法
- 分治演算法-眾數問題演算法
- 【演算法練習】(8)眾數演算法
- 演算法之絕對眾數演算法
- Java實現 藍橋杯 演算法提高 八數碼(BFS)Java演算法
- Java引用計數與實現Java
- Java實現水仙花數Java
- Python演算法實現質數(素數)判斷Python演算法
- 分治法求眾數和重數(含檔案輸入輸出)
- 浮點數演算法的內部實現演算法
- 題目:2.兩數相加 解題思路及Java實現Java
- 【演算法解題報告】求眾數演算法
- 演算法案例2-求冰雹數 java程式碼實現演算法Java
- Visual C++數字影象處理典型演算法及實現C++演算法
- 最大公約數和最小公倍數--java實現Java
- java變數及常量Java變數
- ORACLE 數字演算法的C語言實現Oracle演算法C語言
- 資料結構與演算法——基數排序簡單Java實現資料結構演算法排序Java
- 【重學Java】可變引數Java
- 演算法面試題彙總_2求眾數演算法面試題
- 數值積分公式及龍貝格(Romberg)演算法實現matlab公式演算法Matlab
- 圓圈中最後剩下的數字(Java實現)Java
- 用連結串列的方式實現大數相減-Java實現Java
- (七)一個尋找陣列中眾數的演算法陣列演算法
- 演算法金 | 平均數、眾數、中位數、極差、方差,標準差、頻數、頻率 一“統”江湖演算法
- Python求取資料夾內的檔案數量、子資料夾內的檔案數量Python
- 裁剪演算法 - Cohen Sutherland Clipping的原理及Java實現演算法Java