求取眾數及重數的演算法實現(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;
}
}
相關文章
- 一次數獨生成及解題演算法的剖析(Java實現)演算法Java
- [PHP] 演算法-陣列重複數字統計的PHP實現PHP演算法陣列
- 演算法題:求眾數演算法
- 【演算法】已知必存在眾數,求該眾數 -- Boyer-Moore 投票演算法演算法
- Java中使用指數退避和抖動實現重試Java
- 優化的求眾數方法 - 摩爾投票演算法(演算法思想+求眾數的三種方法+摩爾投票演算法改進版求眾數 II)優化演算法
- 分治演算法-眾數問題演算法
- 演算法:Majority Element(求眾數)演算法
- 【演算法】求眾數-js解法演算法JS
- 【演算法練習】(8)眾數演算法
- Java實現 藍橋杯 演算法提高 八數碼(BFS)Java演算法
- Java引用計數與實現Java
- 浮點數演算法的內部實現演算法
- 題目:2.兩數相加 解題思路及Java實現Java
- 演算法案例2-求冰雹數 java程式碼實現演算法Java
- 數值積分公式及龍貝格(Romberg)演算法實現matlab公式演算法Matlab
- 分治法求眾數和重數(含檔案輸入輸出)
- java變數及常量Java變數
- 用連結串列的方式實現大數相減-Java實現Java
- 【重學Java】可變引數Java
- 均值、中位數、眾數
- PAT1044火星數字(java實現)Java
- PAT1048數字加密(java實現)加密Java
- PAT1019 數字黑洞(java實現)Java
- 求眾數
- Python求取資料夾內的檔案數量、子資料夾內的檔案數量Python
- 演算法練習:求字串的最長重複子串(Java實現)演算法字串Java
- 數字孿生的實現方案及可行性分析
- 演算法面試題彙總_2求眾數演算法面試題
- 演算法金 | 平均數、眾數、中位數、極差、方差,標準差、頻數、頻率 一“統”江湖演算法
- LeetCode 299 猜數字遊戲 Java實現LeetCode遊戲Java
- 給定一個大小為 n 的陣列,找到其中的眾數。眾數是指在陣列中出現次數大於 ⌊ n/2 ⌋ 的元素。陣列
- 【leetcode】求眾數LeetCode
- 力扣演算法經典第一題——兩數之和(Java兩種方式實現)力扣演算法Java
- java實現論文查重Java
- 圖解選擇排序及演算法優化(Java實現)圖解排序演算法優化Java
- 圖解氣泡排序及演算法優化(Java實現)圖解排序演算法優化Java
- java中的鎖及實現原理Java