杂题——1028: [编程入门]自定义函数求一元二次方程

本文介绍了使用Java编程实现一个求解一元二次方程的程序,根据不同判别式(b^2-4ac)的值,计算并输出实数根或共轭复数根,同时关注输出格式和计算精度。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述
求方程 的根,用三个函数分别求当b^2-4ac大于0、等于0、和小于0时的根,并输出结果。从主函数输入a、b、c的值。
输入格式
a b c
输出格式
x1=? x2=?
样例输入
4 1 1
样例输出
x1=-0.125+0.484i x2=-0.125-0.484i

分析:

  • 注意输出的格式和计算过程的精度
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        double a = scanner.nextDouble();
        double b = scanner.nextDouble();
        double c = scanner.nextDouble();
        double delta = b * b - 4 * a * c;
        
        if (delta > 0) {
            twoRoots(a, b, delta);
        } else if (delta == 0) {
            oneRoot(a, b, delta);
        } else {
            complexRoots(a, b, delta);
        }
    }
    
    // 两个实根
    public static void twoRoots(double a, double b, double delta) {
        double x1 = (-b - Math.sqrt(delta)) / (2 * a);
        double x2 = (-b + Math.sqrt(delta)) / (2 * a);
        System.out.printf("x1=%.3f x2=%.3f", x1, x2);
    }
    
    // 一个实根
    public static void oneRoot(double a, double b, double delta) {
        double x = -b / (2 * a);
        System.out.printf("x1=%.3f x2=%.3f", x, x);
    }
    
    // 共轭复根
    public static void complexRoots(double a, double b, double delta) {
        double realPart = -b / (2 * a);
        double imaginaryPart = Math.sqrt(-delta) / (2 * a);
        System.out.printf("x1=%.3f+%.3fi x2=%.3f-%.3fi", realPart, imaginaryPart, realPart, imaginaryPart);
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

戏拈秃笔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值