Поиск комбинации операций + и * для достижения целевого значения - PullRequest
0 голосов
/ 06 февраля 2020

В настоящее время я пытаюсь решить проблему, когда мы берем несколько положительных целых чисел в одной строке и одно целое число во второй строке и находим математические операции для достижения этого значения

пример:

enter image description here

Я застрял на реализации метода N Мне удалось заставить работать метод L

Метод N выполняет умножение перед сложением просто как и в обычной математике

L метод выполняет математические вычисления слева направо, не беспокоясь о том, чтобы сначала выполнить мультипликацию. Вот мой код:

import java.util.Scanner;
import java.lang.Character;
import java.lang.StringBuilder;
import java.util.Arrays;

public class Arithmetic{

    public static String operandBuilder = "";
    public static boolean isPossible = false;

    public static void main(String[] args){

        String inputNumbers;
        String[] stringSplitter = null;
        int[] numbers = null;
        char operation;
        String targetOp;
        int i, target;
        int length = 0;

        Scanner scanner = new Scanner(System.in);
        while(scanner.hasNextLine()){

            inputNumbers = scanner.nextLine();
            // Takes in user input and makes it useable
            targetOp = scanner.nextLine();
            operation = targetOp.charAt(targetOp.length() - 1);
            targetOp = targetOp.substring(0, targetOp.length() - 2);
            operation = Character.toUpperCase(operation);
            target = Integer.parseInt(targetOp);

            // Turns the input numbers into a string, and removes all occurances of spaces
            stringSplitter = null;
            stringSplitter = inputNumbers.split(" ");  
            length = stringSplitter.length;

            // Initializes a new int array with a size that can hold the inputted numbers
            numbers = null;
            numbers = new int[length];

            // Fill the int array with contents from the string array
            for(i = 0; i < length; i++){
                numbers[i] = Integer.parseInt(stringSplitter[i]);
            }

            // If the user specified L operation, run that method. Otherwise, print error
            if(operation == 'L'){
                lrOperation(numbers, target, 0, 0);
            }else if(operation == 'N'){ 
                System.out.println("You printed N!");
            }else{
               System.err.println("ERROR: Please enter L or N for operation only");
            }

            // If the method adds anything to operand, it found a correct answer. The program prints that answer
            // Otherwise, it prints impossible.
            if(operandBuilder.length() > 0){
                System.out.println(operation + " " + (new StringBuilder(operandBuilder).reverse().toString()));
            }else{
                System.out.println(operation + " " + target + " impossible");
            }
            operandBuilder = "";
        }
        // Close the scanner, effectively ending the program
        scanner.close();

    }

    /* Recursively finds any possible solution for LHS solving 
       @param numbers - An int array which stores the numbers to be used
              target  - The int that the program is trying to find a calculation to hit
              sum     - Recursively stores the current sum of previous recursions
              depth   - Keeps track of what depth level the recursion is currently at
       @return boolean - Returns true if a possible calculation is found                  */
    public static boolean lrOperation(int[] numbers, int target, int sum, int depth){

        // If depth is higher than the length of numbers, return false
        if(depth >= numbers.length + 1){
            return false;
        }

        // Gets a digit length of current number to be used later
        int length = String.valueOf(numbers[depth]).length();

        // Checks to see if the current calculation is over the target
        if(!((sum * numbers[depth]) > target) || !((sum + numbers[depth]) > target)){

            // Checks to see if this if this current number is the last in inputs
            if(depth == numbers.length - 1){
                // If any current calculations are on target, return true and begin building the operandString
                if(sum + numbers[depth] == target){

                    isPossible = true;
                    if(length == 1){
                        operandBuilder += numbers[depth];
                    }else{
                        operandBuilder += new StringBuilder(Integer.toString(numbers[depth])).reverse().toString();
                    }
                    operandBuilder += " + ";
                    return true;
                }
                if(sum * numbers[depth] == target){
                    System.out.println("Sum: " + sum);
                    System.out.println("Curr: " + numbers[depth]);
                    int temp = sum * numbers[depth];
                    System.out.println("Sum * Curr: " + temp);
                    isPossible = true;
                    if(length == 1){
                        operandBuilder += numbers[depth];
                    }else{
                        operandBuilder += new StringBuilder(Integer.toString(numbers[depth])).reverse().toString();
                    }
                    operandBuilder += " * ";
                    return true;
                }   
            }else{            
                // Checks to see if the next calculation is over the target or not. If under, keep recurring.
                if(!(sum + numbers[depth] > target)){
                    if (lrOperation(numbers, target, sum + numbers[depth], depth + 1)){
                        // Flag will be thrown if calculation found in previous recursion. Begin building string recursively
                        if(isPossible){
                            if(length == 1){
                                operandBuilder += numbers[depth];
                            }else{
                                operandBuilder += new StringBuilder(Integer.toString(numbers[depth])).reverse().toString();
                            }
                            if(depth > 0){
                                operandBuilder += " + ";
                            }
                        }
                        return true;
                    }                
                }
                // Checks to see if the next calculation is over the target or not. If under, keep recurring.
                if(!(sum * numbers[depth] > target)){
                    if(depth == 0){
                        sum = 1;
                    }
                    if (lrOperation(numbers, target, sum * numbers[depth], depth + 1)){
                        // Flag will be thrown if calculation found in previous recursion. Begin building string recursively
                        if(isPossible){
                            if(length == 1){
                                operandBuilder += numbers[depth];
                            }else{
                                operandBuilder += new StringBuilder(Integer.toString(numbers[depth])).reverse().toString();
                            }
                            if(depth > 0){
                                operandBuilder += " * ";
                            }
                        }
                        return true;
                    }
                }              
            }
        }
        return false;
    }




    }

любая помощь приветствуется

...