|
16 | 16 | @SimpleObject(external = true) |
17 | 17 |
|
18 | 18 | public class ColinTreeMath extends AndroidNonvisibleComponent implements Component { |
19 | | - public static final int VERSION = 1; |
| 19 | + public static final int VERSION = 2; |
20 | 20 | private ComponentContainer container; |
21 | 21 | private Context context; |
22 | 22 | private static final String LOG_TAG = "ColinTreeMath"; |
23 | 23 | public ColinTreeMath(ComponentContainer container) { |
24 | 24 | super(container.$form()); |
25 | 25 | this.container = container; |
26 | 26 | context = (Context) container.$context(); |
27 | | - Log.d(LOG_TAG, "ColinTreeMath Created" ); |
| 27 | + Log.d(LOG_TAG, "ColinTreeMath Created"); |
28 | 28 | } |
29 | 29 |
|
30 | 30 | // Max - Zui Da Shu |
31 | 31 | @SimpleFunction(description = "Find the max number in the list, return min double if the list is empty. Also, please make sure there are all number in the list") |
32 | | - public double Max(YailList list){ |
33 | | - Object[] lst=list.toArray(); |
34 | | - double tmp,max=Double.MIN_VALUE; |
35 | | - for (int i=0;i<list.size();i++){ |
36 | | - tmp=new Double(lst[i].toString()); |
37 | | - if (max<tmp) max=tmp; |
| 32 | + public double Max(YailList list) { |
| 33 | + Object[] lst = list.toArray(); |
| 34 | + double tmp, max = Double.MIN_VALUE; |
| 35 | + for (int i = 0; i < list.size(); i++) { |
| 36 | + tmp = new Double(lst[i].toString()); |
| 37 | + if (max < tmp) max = tmp; |
38 | 38 | } |
39 | 39 | return max; |
40 | 40 | } |
41 | 41 | // Min - Zui Xiao Shu |
42 | 42 | @SimpleFunction(description = "Find the min number in the list, return max double if the list is empty. Also, please make sure there are all number in the list") |
43 | | - public double Min(YailList list){ |
44 | | - Object[] lst=list.toArray(); |
45 | | - double tmp,min=Double.MAX_VALUE; |
46 | | - for (int i=0;i<list.size();i++){ |
47 | | - tmp=new Double(lst[i].toString()); |
48 | | - if (min>tmp) min=tmp; |
| 43 | + public double Min(YailList list) { |
| 44 | + Object[] lst = list.toArray(); |
| 45 | + double tmp, min = Double.MAX_VALUE; |
| 46 | + for (int i = 0; i < list.size(); i++) { |
| 47 | + tmp = new Double(lst[i].toString()); |
| 48 | + if (min > tmp) min = tmp; |
49 | 49 | } |
50 | 50 | return min; |
51 | 51 | } |
52 | 52 | // Average - Ping Jun |
53 | 53 | @SimpleFunction(description = "Return the average of the numbers in the list. Please make sure there are all number in the list") |
54 | | - public double Average(YailList list){ |
55 | | - Object[] lst=list.toArray(); |
56 | | - double tmp,tot=0; |
57 | | - for (int i=0;i<list.size();i++){ |
58 | | - tmp=new Double(lst[i].toString()); |
59 | | - tot+=tmp; |
| 54 | + public double Average(YailList list) { |
| 55 | + Object[] lst = list.toArray(); |
| 56 | + double tmp, tot = 0; |
| 57 | + for (int i = 0; i < list.size(); i++) { |
| 58 | + tmp = new Double(lst[i].toString()); |
| 59 | + tot += tmp; |
60 | 60 | } |
61 | | - return tot/list.size(); |
| 61 | + return tot / list.size(); |
62 | 62 | } |
63 | 63 | // Bubble Sort in ascending order - Sheng Xu Mao Pao |
64 | 64 | @SimpleFunction(description = "(Sheng Xu Pai Xu - Mao Pao Pai Xu) Sort the number in the list in ascending order. Please make sure there are all number in the list") |
65 | | - public YailList SortAscend(YailList list){ |
66 | | - Object[] rst=new Object[list.size()],lst=list.toArray(); |
67 | | - double[] forSort=new double[list.size()]; |
| 65 | + public YailList SortAscend(YailList list) { |
| 66 | + Object[] rst = new Object[list.size()], lst=list.toArray(); |
| 67 | + double[] forSort = new double[list.size()]; |
68 | 68 | double tmp; |
69 | | - for (int i=0;i<list.size();i++){ |
70 | | - forSort[i]=new Double(lst[i].toString()); |
| 69 | + for (int i = 0; i < list.size(); i++) { |
| 70 | + forSort[i] = new Double(lst[i].toString()); |
71 | 71 | } |
72 | | - for (int i=0;i<(list.size()-1);i++){ |
73 | | - for (int j=i+1;j<list.size();j++){ |
74 | | - if (forSort[i]>forSort[j]){ |
75 | | - tmp=forSort[i]; |
76 | | - forSort[i]=forSort[j]; |
77 | | - forSort[j]=tmp; |
| 72 | + for (int i = 0; i < list.size() - 1; i++) { |
| 73 | + for (int j = i + 1; j < list.size(); j++) { |
| 74 | + if (forSort[i] > forSort[j]) { |
| 75 | + tmp = forSort[i]; |
| 76 | + forSort[i] = forSort[j]; |
| 77 | + forSort[j] = tmp; |
78 | 78 | } |
79 | 79 | } |
80 | 80 | } |
81 | | - for (int i=0;i<list.size();i++){ |
82 | | - rst[i]=forSort[i]; |
| 81 | + for (int i = 0; i < list.size(); i++) { |
| 82 | + rst[i] = forSort[i]; |
83 | 83 | } |
84 | 84 | return YailList.makeList(rst); |
85 | 85 | } |
86 | 86 | // Sort in descending order - Jiang Xu Mao Pao |
87 | 87 | @SimpleFunction(description = "(Jiang Xu Pai Xu - Mao Pao Pai Xu) Sort the number in the list in decending order. Please make sure there are all number in the list") |
88 | | - public YailList SortDecend(YailList list){ |
89 | | - Object[] rst=new Object[list.size()],lst=list.toArray(); |
90 | | - double[] forSort=new double[list.size()]; |
| 88 | + public YailList SortDecend(YailList list) { |
| 89 | + Object[] rst = new Object[list.size()], lst = list.toArray(); |
| 90 | + double[] forSort = new double[list.size()]; |
91 | 91 | double tmp; |
92 | | - for (int i=0;i<list.size();i++){ |
93 | | - forSort[i]=new Double(lst[i].toString()); |
| 92 | + for (int i = 0; i < list.size(); i++) { |
| 93 | + forSort[i] = new Double(lst[i].toString()); |
94 | 94 | } |
95 | | - for (int i=0;i<(list.size()-1);i++){ |
96 | | - for (int j=i+1;j<list.size();j++){ |
97 | | - if (forSort[i]<forSort[j]){ |
98 | | - tmp=forSort[i]; |
99 | | - forSort[i]=forSort[j]; |
100 | | - forSort[j]=tmp; |
| 95 | + for (int i = 0; i < list.size() - 1; i++) { |
| 96 | + for (int j = i + 1; j < list.size(); j++) { |
| 97 | + if (forSort[i] < forSort[j]) { |
| 98 | + tmp = forSort[i]; |
| 99 | + forSort[i] = forSort[j]; |
| 100 | + forSort[j] = tmp; |
101 | 101 | } |
102 | 102 | } |
103 | 103 | } |
104 | | - for (int i=0;i<list.size();i++){ |
105 | | - rst[i]=forSort[i]; |
| 104 | + for (int i = 0; i < list.size(); i++) { |
| 105 | + rst[i] = forSort[i]; |
106 | 106 | } |
107 | 107 | return YailList.makeList(rst); |
108 | 108 | } |
109 | 109 | //greatest common divisor - Zui Da Gong Yue Shu |
110 | 110 | @SimpleFunction(description = "(Zui Da Gong Yue Shu)Return the greatest common divisor, auto-round down into integer if it is not") |
111 | | - public int GCD(int number1,int number2){ |
112 | | - if (number1==number2){ |
| 111 | + public int GCD(int number1, int number2) { |
| 112 | + if (number1 == number2) { |
113 | 113 | return number1; |
114 | 114 | } |
115 | | - if (number1<number2){ |
116 | | - return GCD(number2,number1); |
117 | | - }else{ |
118 | | - if ((number1%2==0)&&(number2%2==0)){ |
119 | | - return GCD(number1>>1,number2>>1)<<1; |
120 | | - }else if ((number1%2==0)&&(number2%2!=0)){ |
121 | | - return GCD(number1>>1,number2); |
122 | | - }else if ((number1%2!=0)&&(number2%2==0)){ |
123 | | - return GCD(number1,number2>>1); |
124 | | - }else{ |
125 | | - return GCD(number2,number1-number2); |
| 115 | + if (number1 < number2) { |
| 116 | + return GCD(number2, number1); |
| 117 | + } else { |
| 118 | + if ((number1 % 2 == 0) && (number2 % 2 == 0)) { |
| 119 | + return GCD(number1 >> 1, number2 >> 1) << 1; |
| 120 | + } else if ((number1 % 2 == 0) && (number2 % 2 != 0)) { |
| 121 | + return GCD(number1 >> 1, number2); |
| 122 | + } else if ((number1 % 2 != 0) && (number2 % 2 == 0)) { |
| 123 | + return GCD(number1, number2 >> 1); |
| 124 | + } else { |
| 125 | + return GCD(number2, number1 - number2); |
126 | 126 | } |
127 | 127 | } |
128 | | - //return number2?gcd(b,a%b):a; //from qq1139855151 He Bei Shi Jia Zhuang Chen |
| 128 | + // return number2 ? gcd(b, a % b) : a; //from qq1139855151 He Bei Shi Jia Zhuang Chen |
129 | 129 | } |
130 | 130 | //Least common multiple - Zui Xiao Gong Bei Shu |
131 | 131 | @SimpleFunction(description = "(Zui Xiao Gong Bei Shu)Return the least common multiple, auto-round down into integer if it is not") |
132 | | - public int LCM(int number1,int number2){ |
133 | | - int gcd=GCD(number1,number2); |
134 | | - return number1*number2/gcd; |
| 132 | + public int LCM(int number1, int number2) { |
| 133 | + int gcd = GCD(number1, number2); |
| 134 | + return number1 * number2 / gcd; |
135 | 135 | } |
136 | 136 | //Power - Qiu Mi |
137 | 137 | @SimpleFunction(description = "(Qiu Mi: number^n)Return number^n") |
138 | | - public double Power(double number,double n){ |
139 | | - double tmp,y=1; |
140 | | - n=Math.floor(n); |
141 | | - while (true){ |
142 | | - tmp=n%2; |
143 | | - n=Math.floor(n/2); |
144 | | - if (tmp==1) |
145 | | - y=y*number; |
146 | | - if (n==0) |
| 138 | + public double Power(double number, double n) { |
| 139 | + double tmp, y = 1; |
| 140 | + n = Math.floor(n); |
| 141 | + while (true) { |
| 142 | + tmp = n % 2; |
| 143 | + n = Math.floor(n / 2); |
| 144 | + if (tmp == 1) |
| 145 | + y = y * number; |
| 146 | + if (n == 0) |
147 | 147 | break; |
148 | | - number=number*number; |
| 148 | + number = number * number; |
149 | 149 | } |
150 | 150 | return y; |
151 | 151 | } |
152 | 152 | //Pi - π |
153 | 153 | @SimpleFunction(description = "(π)Return pi") |
154 | | - public double Pi(){ |
| 154 | + public double Pi() { |
155 | 155 | return Math.PI; |
156 | 156 | } |
157 | 157 | //e - e |
158 | 158 | @SimpleFunction(description = "(e)Return Natural logarithm e") |
159 | | - public double e(){ |
| 159 | + public double e() { |
160 | 160 | return Math.E; |
161 | 161 | } |
162 | 162 | //Cube root (Li Fang Gen) |
163 | 163 | @SimpleFunction(description = "(Li Fang Gen)Return 3√num") |
164 | | - public double CbRt(double number){ |
| 164 | + public double CbRt(double number) { |
165 | 165 | return Math.cbrt(number); |
166 | 166 | } |
167 | 167 | //log10 |
168 | 168 | @SimpleFunction(description = "Return Log 10,number") |
169 | | - public double Log10(double number){ |
| 169 | + public double Log10(double number) { |
170 | 170 | return Math.log10(number); |
171 | 171 | } |
172 | 172 | //1/√num |
173 | 173 | @SimpleFunction(description = "Return 1/√num") |
174 | | - public double ROTSR(double number){ |
175 | | - return 1/Math.sqrt(number); |
| 174 | + public double ROTSR(double number) { |
| 175 | + return 1 / Math.sqrt(number); |
176 | 176 | } |
177 | 177 | //sqrt(number1^2 +number2^2) |
178 | 178 | @SimpleFunction(description = "Return sqrt(number1^2 +number2^2)") |
179 | | - public double hypot(double number1,double number2){ |
180 | | - return Math.hypot(number1,number2); |
| 179 | + public double hypot(double number1, double number2) { |
| 180 | + return Math.hypot(number1, number2); |
181 | 181 | } |
182 | 182 | //Prime number (Zhi Shu) |
183 | 183 | @SimpleFunction(description = "Return true if number is prime number") |
184 | | - public boolean Prime(int number){ |
185 | | - if (number==2) |
| 184 | + public boolean Prime(int number) { |
| 185 | + if (number == 2) |
186 | 186 | return true; |
187 | | - else if (number%2==0) |
| 187 | + else if (number % 2 == 0) |
188 | 188 | return false; |
189 | | - else for (int i=3;i<=Math.sqrt(number);i+=2) |
190 | | - if (number%i==0) |
| 189 | + else for (int i = 3; i <= Math.sqrt(number); i += 2) |
| 190 | + if (number % i == 0) |
191 | 191 | return false; |
192 | 192 | return true; |
193 | 193 | } |
|
0 commit comments