Calculate Number Frequency
騰訊麵試題:給你 10 分鍾時間,根據上排給出十個數,在其下排填出對應的十個數,
要求下排每個數都是先前上排那十個數在下排出現的次數。
上排的十個數如下:
【0,1,2,3,4,5,6,7,8,9】
舉一個例子,數值: 0,1,2,3,4,5,6,7,8,9
分配: 6,2,1,0,0,0,1,0,0,0
0 在下排出現了 6 次,1 在下排出現了 2 次,
2 在下排出現了 1 次,3 在下排出現了 0 次....
以此類推..
package shuai.study.frequency; /** * @author shengshu * */ public class NumberFrequency { private final int len = 10; private int[] numberArray = null; private int[] frequencyArray = null; public NumberFrequency() { numberArray = new int[len]; frequencyArray = new int[len]; } // Initialize numberArray public void initNumberArray() { for (int i = 0; i < len; i++) { numberArray[i] = i; } } // Get final frequencyArray public int[] getFrequencyArray() { while (isSetFrequencyArray(numberArray)) { isSetFrequencyArray(numberArray); } return frequencyArray; } // Whether set frequencyArray according to judging 'frequencyArray[i] != frequency' public boolean isSetFrequencyArray(int[] numberArray) { boolean setNextFrequencyFlag = false; for (int i = 0; i < len; i++) { int frequency = getFrequency(numberArray[i]); if (frequencyArray[i] != frequency) { frequencyArray[i] = frequency; setNextFrequencyFlag = true; } } return setNextFrequencyFlag; } // Get numberArray's element(number) frequency public int getFrequency(int number) { int frequency = 0; for (int i = 0; i < len; i++) { if (frequencyArray[i] == number) { frequency++; } } return frequency; } // Print array public void printArray(int[] array) { for (int i = 0; i < array.length; i++) { System.out.print(array[i] + "\t"); } } // Main thread public static void main(String[] args) { NumberFrequency numberFrequency = new NumberFrequency(); numberFrequency.initNumberArray(); int[] frequencyArray = numberFrequency.getFrequencyArray(); numberFrequency.printArray(frequencyArray); } }
最後更新:2017-04-03 05:39:35