java解一元一次方程

复旦大学上机题(二)

  • 解方程。给定一个字符串,代表一个一元一次方程。如果有解求解,输出格式“x=数字” ,如果解的个数无穷,输出 “infinite
    solutions”。如果没有解输出“no solution”

    字符串长度不超过 256 。

  • 输入格式: 输入一个一元一次方程,未知数用x表示。

  • 输出格式: 输出 “x=数字” 或者 “infinite solutions”或者“no solution” 输入样例: 10x-2x-8=4x+7+x

  • 输出样例:x=5

package cn.liuliu;

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

public class Main {

    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        String n = scan.nextLine();
        n = n.replaceAll(" ", "");

        float re;
        String[] a;
        a = n.split("=");
        String l = a[0];//等式左边
        String r = a[1];//等式右边

        char[] arr = r.toCharArray();
        //将右边移到左边
        for (int i = 0; i < arr.length; i++) {
            if (arr[i] == '-') {
                l = l + '+';
            } else if (arr[i] == '+') {
                l = l + '-';
            } else {
                if (i == 0) {
                    l = l + '-' + arr[i];
                } else {
                    l = l + arr[i];
                }

            }
        }

        // System.out.println(l);
        //处理左边
        char[] arr2 = l.toCharArray();
        int r_cc = 0;//等式右边放常数,常数和
        String temp_c = "";//临时数据
        List<String> x_list = new ArrayList<String>();//把带x的放一个数组

        for (int i = 0; i < arr2.length; i++) {
            if (arr2[i] == '-') {//负号,则下一步是减操作
                if (temp_c.contains("x")) {//前方有x,放入x数组
                    x_list.add(temp_c);//添加进x_list
                    temp_c = "-";//下一个数带上负号,为负数
                } else {//没有x,则是常数
                    r_cc = r_cc - Integer.parseInt(temp_c);//加到右边值
                    temp_c = "-";//下一个数带上负号,为负数
                }
            } else if (arr2[i] == '+') {//加号,则下一步是加操作
                if (temp_c.contains("x")) {//前方有x,放入x数组
                    x_list.add(temp_c);//添加进x_list
                    temp_c = "+";//下一个数带上正号,为正数
                } else {//没有x,则是常数
                    r_cc = r_cc - Integer.parseInt(temp_c);//加到右边值
                    temp_c = "+";//下一个数带上正号,为正数
                }
            } else {
                temp_c = temp_c + arr2[i];//不包含就直接加到临时字符串中
            }
        }
        if (!temp_c.equals("")) {//最后一个字符串
            if (temp_c.contains("x")) {//前方有x,放入x数组
                x_list.add(temp_c);//添加进x_list
            } else {
                r_cc = r_cc + Integer.parseInt(temp_c);//加到右边值
            }
        }
        System.out.println(x_list);
        System.out.println(r_cc);

        int l_cc = 0;//左边x的前缀值
        for (int i = 0; i < x_list.size(); i++) {
            String x1 = x_list.get(i);
            x1 = x1.replaceAll("x", "");
            if (x1.contains("+")) {
                if (x1.equals("+"))//+x这种情况
                    x1 = "1";
            } else if (x1.contains("-")) {
                if (x1.equals("-"))//-x这种情况
                    x1 = "-1";
            } else {
                if (x1.equals(""))//首个为x这种情况
                    x1 = "1";
            }
            l_cc = l_cc + Integer.parseInt(x1);//加到左边前缀值
        }
        //   System.out.println(l_cc);
        try {
            re = r_cc / (float) l_cc;
            System.out.println("x=" + re);
        } catch (Exception ex) {
            System.out.println("no solution");
        }
    }
}

看到了随手写一下,有更好的写法可以交流一下

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值