أي 4 أرقام من 1 إلى 13 تجمع وتطرح وتضرب وتقسم لتحصل على 24 نقطة.
مبدأ التنفيذ:
1) ترتيب ودمج 4 أرقام
2) احسب إمكانية كل التقليب والجمع
Cal24.java
import java.util.HashSet;import java.util.Set; public class Cal24 { الدقة المزدوجة النهائية الثابتة الخاصة = 0.00001; = new int[4]; for (int i = 0; i < inputs.length; i++) { digits[i] = Integer.valueOf(inputs[i]); } return new String[]{calc(digits)}; } public String calc(final int data[]){ Final Set<String> out = new HashSet<String>(); رقم المجموعة = new Combination() { @Override protected void Handle(int[] result) { Final int[] r = result; Combination oper = new Combination(){ @Override protected void Handle(int[] c) { double x = r[0]; for (int i = 0; i < r.length - 1; i++) { x = doCalculate(x, r[i + 1], c[i ]); } if(Math.abs(Math.abs(x) - الهدف) < الدقة || Math.abs(Math.abs(1/x) - الهدف) < الدقة){ StringBuilder sb = جديد StringBuilder(); for (int j = 0; j < r. length; j++) { sb.append(r[j]); if(j != r. length - 1){ sb.append(getOperation(c[ j])); out.add(sb.toString()); 3}, data. length - 1, true); } }; digit.combine(data); StringBuilder sb = new StringBuilder(); /n"); } return sb.toString(); } public double doCalculate(double x, double y, int Operation){ التبديل (العملية) { الحالة 0: return x + y; case 1: return x - y; case 2: return x * y; case 3: return x / y; ) { case 0: return "+"; الحالة 1: return "-"; الحالة 2: return "*"; الحالة 3: return "/"; main(String[] args) { System.out.println(new Cal24().calc(new int[]{1, 5, 5, 5}));Combination.java
تجميع فئة مجردة عامة { تكرار منطقي خاص إجمالي int = 0؛ public void Combine(int data[]){ Combine(data, data. length, false } public void Combine(int data[], int count){ Combine(data, count, false); } public void Combine(int data[], int count, boolean Repeat){ this.repeat = Repeat; int times = data. length; (int)Math.pow(times, count); for (int i = 0; i < size; i++) { int[] result = toArray(data, i, count); result); Total ++; } } } public int[] toArray(int data[], int i, int count){ int [] indices = new int[count]; data. length; for (int j = 0; j < count; j++) { int temp = 0; if(i > 0){ temp = i%times; ] = temp; } if(!repeat){ // إزالة التكرار for (int x = 0; x < count; x++) { for(int y = 0; y < count; y++){ if(x != y){ if(indices[x] == indices[y]) return null; } } } } int [] result = new int[count] for (int x = 0; x < count; x++) { int Selected = data[indices[x]]; result[x] = Selected; نتيجة)؛}ما ورد أعلاه هو محتوى هذه المقالة بالكامل، وآمل أن تنال إعجابكم جميعًا.