问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

java构造一个复数类

发布网友 发布时间:2022-06-24 19:08

我来回答

3个回答

热心网友 时间:2023-10-12 14:38

import java.awt.Dimension;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;

import javax.swing.*;
import javax.swing.WindowConstants;

public class MainFrame extends JFrame implements ActionListener
{
private JTextField textField;
public MainFrame()
{
super();
setSize(new Dimension(320, 210));
setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
setTitle("复数");
getContentPane().setLayout(null);

textField = new JTextField();
textField.setBounds(161, 67, 123, 24);
getContentPane().add(textField);

final JLabel label = new JLabel();
label.setText("请输入一个复数");
label.setBounds(39, 70, 121, 18);
getContentPane().add(label);

final JButton button = new JButton();
button.setText("确定");
button.setBounds(161, 116, 123, 27);
button.addActionListener(this);
getContentPane().add(button);
}

public void actionPerformed(ActionEvent e)
{
String complexString = textField.getText();
if(!complexString.matches("\\d+\\+\\d+i"))
{
return;
}
String[] numGroup = complexString.split("\\+");
String a = numGroup[0];
String b = numGroup[1].substring(0, numGroup[1].length() - 1);
JOptionPane.showMessageDialog(this
, "此复数实部为:" + a + " 虚部为:" + b
, "结果"
, JOptionPane.INFORMATION_MESSAGE);
}

public static void main(String[] args)
{
new MainFrame().show();
}

}

参考资料:csdn

热心网友 时间:2023-10-12 14:39

/**
* 操作复数的类Complex

* @author 周长发
* @version 1.0
*/
public class Complex
{
private double real = 0.0; // 复数的实部
private double imaginary = 0.0; // 复数的虚部
private double eps = 0.0; // 缺省精度

/**
* 基本构造函数
*/
public Complex()
{
}

/**
* 指定值构造函数
*
* @param dblX - 指定的实部
* @param dblY - 指定的虚部
*/
public Complex(double dblX, double dblY)
{
real = dblX;
imaginary = dblY;
}

/**
* 拷贝构造函数
*
* @param other - 源复数
*/
public Complex(Complex other)
{
real = other.real;
imaginary = other.imaginary;
}

/**
* 根据"a,b"形式的字符串来构造复数,以a为复数的实部,b为复数的虚部
*
* @param s - "a,b"形式的字符串,a为复数的实部,b为复数的虚部
* @param sDelim - a, b之间的分隔符
*/
public Complex(String s, String sDelim)
{
setValue(s, sDelim);
}

/**
* 设置复数运算的精度
*
* @param newEps - 新的精度值
*/
public void setEps(double newEps)
{
eps = newEps;
}

/**
* 取复数的精度值
*
* @return double型,复数的精度值
*/
public double getEps()
{
return eps;
}

/**
* 指定复数的实部
*
* @param dblX - 复数的实部
*/
public void setReal(double dblX)
{
real = dblX;
}

/**
* 指定复数的虚部
*
* @param dblY - 复数的虚部
*/
public void setImag(double dblY)
{
imaginary = dblY;
}

/**
* 取复数的实部
*
* @return double 型,复数的实部
*/
public double getReal()
{
return real;
}

/**
* 取复数的虚部
*
* @return double 型,复数的虚部
*/
public double getImag()
{
return imaginary;
}

/**
* 指定复数的实部和虚部值
*
* @param real - 指定的实部
* @param imag - 指定的虚部
*/
public void setValue(double real, double imag)
{
setReal(real);
setImag(imag);
}

/**
* 将"a,b"形式的字符串转化为复数,以a为复数的实部,b为复数的虚部
*
* @param s - "a,b"形式的字符串,a为复数的实部,b为复数的虚部
* @param sDelim - a, b之间的分隔符
*/
public void setValue(String s, String sDelim)
{
int nPos = s.indexOf(sDelim);
if (nPos == -1)
{
s = s.trim();
real = Double.parseDouble(s);
imaginary = 0;
}
else
{
int nLen = s.length();
String sLeft = s.substring(0, nPos);
String sRight = s.substring(nPos+1, nLen);
sLeft = sLeft.trim();
sRight = sRight.trim();
real = Double.parseDouble(sLeft);
imaginary = Double.parseDouble(sRight);
}
}

/**
* 将复数转化为"a+bj"形式的字符串
*
* @return String 型,"a+bj"形式的字符串
*/
public String toString()
{
String s;
if (real != 0.0)
{
if (imaginary > 0)
s = new Float(real).toString() + "+" + new Float(imaginary).toString() + "j";
else if (imaginary < 0)
s = new Float(real).toString() + "-" + new Float(-1*imaginary).toString() + "j";
else
s = new Float(real).toString();
}
else
{
if (imaginary > 0)
s = new Float(imaginary).toString() + "j";
else if (imaginary < 0)
s = new Float(-1*imaginary).toString() + "j";
else
s = new Float(real).toString();
}

return s;
}

/**
* 比较两个复数是否相等
*
* @param cpxX - 用于比较的复数
* @return boolean型,相等则为true,否则为false
*/
public boolean equal(Complex cpxX)
{
return Math.abs(real - cpxX.real) <= eps &&
Math.abs(imaginary - cpxX.imaginary) <= eps;
}

/**
* 给复数赋值
*
* @param cpxX - 用于给复数赋值的源复数
* @return Complex型,与cpxX相等的复数
*/
public Complex setValue(Complex cpxX)
{
real = cpxX.real;
imaginary = cpxX.imaginary;

return this;
}

/**
* 实现复数的加法
*
* @param cpxX - 与指定复数相加的复数
* @return Complex型,指定复数与cpxX相加之和
*/
public Complex add(Complex cpxX)
{
double x = real + cpxX.real;
double y = imaginary + cpxX.imaginary;

return new Complex(x, y);
}

/**
* 实现复数的减法
*
* @param cpxX - 与指定复数相减的复数
* @return Complex型,指定复数减去cpxX之差
*/
public Complex subtract(Complex cpxX)
{
double x = real - cpxX.real;
double y = imaginary - cpxX.imaginary;

return new Complex(x, y);
}

/**
* 实现复数的乘法
*
* @param cpxX - 与指定复数相乘的复数
* @return Complex型,指定复数与cpxX相乘之积
*/
public Complex multiply(Complex cpxX)
{
double x = real * cpxX.real - imaginary * cpxX.imaginary;
double y = real * cpxX.imaginary + imaginary * cpxX.real;

return new Complex(x, y);
}

/**
* 实现复数的除法
*
* @param cpxX - 与指定复数相除的复数
* @return Complex型,指定复数除与cpxX之商
*/
public Complex divide(Complex cpxX)
{
double e, f, x, y;

if (Math.abs(cpxX.real) >= Math.abs(cpxX.imaginary))
{
e = cpxX.imaginary / cpxX.real;
f = cpxX.real + e * cpxX.imaginary;

x = (real + imaginary * e) / f;
y = (imaginary - real * e) / f;
}
else
{
e = cpxX.real / cpxX.imaginary;
f = cpxX.imaginary + e * cpxX.real;

x = (real * e + imaginary) / f;
y = (imaginary * e - real) / f;
}

return new Complex(x, y);
}

/**
* 计算复数的模
*
* @return double型,指定复数的模
*/
public double abs()
{
// 求取实部和虚部的绝对值
double x = Math.abs(real);
double y = Math.abs(imaginary);

if (real == 0)
return y;
if (imaginary == 0)
return x;

// 计算模
if (x > y)
return (x * Math.sqrt(1 + (y / x) * (y / x)));

return (y * Math.sqrt(1 + (x / y) * (x / y)));
}

/**
* 计算复数的根
*
* @param n - 待求根的根次
* @param cpxR - Complex型数组,长度为n,返回复数的所有根
*/
public void root(int n, Complex[] cpxR)
{
if (n<1)
return;

double q = Math.atan2(imaginary, real);
double r = Math.sqrt(real*real + imaginary*imaginary);
if (r != 0)
{
r = (1.0/n)*Math.log(r);
r = Math.exp(r);
}

for (int k=0; k<=n-1; k++)
{
double t = (2.0*k*3.1415926+q)/n;
cpxR[k] = new Complex(r*Math.cos(t), r*Math.sin(t));
}
}

/**
* 计算复数的实幂指数
*
* @param dblW - 待求实幂指数的幂次
* @return Complex型,复数的实幂指数值
*/
public Complex pow(double dblW)
{
// 常量
final double PI = 3.14159265358979;

// 局部变量
double r, t;

// 特殊值处理
if ((real == 0) && (imaginary == 0))
return new Complex(0, 0);

// 幂运算公式中的三角函数运算
if (real == 0)
{
if (imaginary > 0)
t = 1.5707963268;
else
t = -1.5707963268;
}
else
{
if (real > 0)
t = Math.atan2(imaginary, real);
else
{
if (imaginary >= 0)
t = Math.atan2(imaginary, real) + PI;
else
t = Math.atan2(imaginary, real) - PI;
}
}

// 模的幂
r = Math.exp(dblW * Math.log(Math.sqrt(real * real + imaginary * imaginary)));

// 复数的实幂指数
return new Complex(r * Math.cos(dblW * t), r * Math.sin(dblW * t));
}

/**
* 计算复数的复幂指数
*
* @param cpxW - 待求复幂指数的幂次
* @param n - 控制参数,默认值为0。当n=0时,求得的结果为复幂指数的主值
* @return Complex型,复数的复幂指数值
*/
public Complex pow(Complex cpxW, int n)
{
// 常量
final double PI = 3.14159265358979;
// 局部变量
double r, s, u, v;

// 特殊值处理
if (real == 0)
{
if (imaginary == 0)
return new Complex(0, 0);

s = 1.5707963268 * (Math.abs(imaginary) / imaginary + 4 * n);
}
else
{
s = 2 * PI * n + Math.atan2(imaginary, real);

if (real < 0)
{
if (imaginary > 0)
s = s + PI;
else
s = s - PI;
}
}

// 求幂运算公式
r = 0.5 * Math.log(real * real + imaginary * imaginary);
v = cpxW.real * r + cpxW.imaginary * s;
u = Math.exp(cpxW.real * r - cpxW.imaginary * s);

return new Complex(u * Math.cos(v), u * Math.sin(v));
}

/**
* 计算复数的自然对数
*
* @return Complex型,复数的自然对数值
*/
public Complex log()
{
double p = Math.log(Math.sqrt(real*real + imaginary*imaginary));
return new Complex(p, Math.atan2(imaginary, real));
}

/**
* 计算复数的正弦
*
* @return Complex型,复数的正弦值
*/
public Complex sin()
{
int i;
double x, y, y1, br, b1, b2;
double[] c = new double[6];

// 切比雪夫公式的常数系数
c[0] = 1.13031820798497;
c[1] = 0.04433684984866;
c[2] = 0.00054292631191;
c[3] = 0.00000319843646;
c[4] = 0.00000001103607;
c[5] = 0.00000000002498;

y1 = Math.exp(imaginary);
x = 0.5 * (y1 + 1 / y1);
br = 0;
if (Math.abs(imaginary) >= 1)
y = 0.5 * (y1 - 1 / y1);
else
{
b1 = 0;
b2 = 0;
y1 = 2 * (2 * imaginary * imaginary - 1);
for (i = 5; i >=0; --i)
{
br = y1 * b1 - b2 - c[i];
if (i != 0)
{
b2 = b1;
b1 = br;
}
}

y = imaginary * (br - b1);
}

// 组合计算结果
x = x * Math.sin(real);
y = y * Math.cos(real);

return new Complex(x, y);
}

/**
* 计算复数的余弦
*
* @return Complex型,复数的余弦值
*/
public Complex cos()
{
int i;
double x, y, y1, br, b1, b2;
double[] c = new double[6];

// 切比雪夫公式的常数系数
c[0] = 1.13031820798497;
c[1] = 0.04433684984866;
c[2] = 0.00054292631191;
c[3] = 0.00000319843646;
c[4] = 0.00000001103607;
c[5] = 0.00000000002498;

y1 = Math.exp(imaginary);
x = 0.5 * (y1 + 1 / y1);
br = 0;
if (Math.abs(imaginary) >= 1)
y = 0.5 * (y1 - 1 / y1);
else
{
b1 = 0;
b2 = 0;
y1 = 2 * (2 * imaginary * imaginary - 1);
for (i=5 ; i>=0; --i)
{
br = y1 * b1 - b2 - c[i];
if (i != 0)
{
b2 = b1;
b1 = br;
}
}

y = imaginary * (br - b1);
}

// 组合计算结果
x = x * Math.cos(real);
y = -y * Math.sin(real);

return new Complex(x, y);
}

/**
* 计算复数的正切
*
* @return Complex型,复数的正切值
*/
public Complex tan()
{
return sin().divide(cos());
}
}

热心网友 时间:2023-10-12 14:39

说实话^不懂
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
你能用一句话表达这个画面吗 专科学高铁乘务专业能找到工作吗 广西理工职业技术学院怎样啊?? 月亮星座怎么配对,月亮星座配对查询爱情 广西理工职业技术学院到底好不好的 最甜蜜的月亮星座组合,最冷血的月亮星座 包子怎么做才松软 包子如何做才松软 包子店的包子发酵怎么这么松软 专做俄罗斯业务的货代公司 大理石地板怎么拖干净又亮妙招 海信电视操作使用说明- 问一问 ASME ANSI是个怎样的关系,求 旧浴缸如何翻新,旧浴缸如何翻新知识 翻新鱼缸 索尼KD-55X8000e怎么强刷- 问一问 歌词里有“摩天轮”的歌曲有哪些 怎么去除别人涂的马赛克? 教育叙事之新教育实施方案3篇朴新教育 新教育新生命新希望的作文怎么写? 头型比较尖的人扎什么头发好看学生 苹果xsmas256内存可以随便升级系统吗,会不会卡- 问一问 微米级距离测量方法 求一份水电设计图,户型平面图奉上 水电施工用cad平面设计图就行吗 百度为什么要注册抖音 为什么现在很多媒体都入驻抖音快手等热门平台? 抖音小店入驻怎么样?为什么我周围越来越多的人入驻了 如何让老公更爱你 女人必知五个风水秘诀 在ps中使用消失点时,里面用图章工具怎么选择自己想要的选择区域? 船政交通职业学院航海技术 ,三年期间学什么 到毕业 拿到什么证_百度问一问 速钓拉饵术 是谁最开始使用? 或者说 是谁将拉丝粉制作并且使用到钓鱼中去的? 说说其发展过程!谢谢 老师你好我想知道客户留存率是怎么计算的 有计算公式吗?- 问一问 风水住宅 风水上坐北朝南到底是什么意思 手机号码绑定了一个不用的,怎么解除? 中国电信绑定怎么解除 不想绑定手机号要怎么解除? 石家庄高新区珠江大道252号西三门到北站公交车路线 坐572路公交从河北交通职业技术学院到谈固多少分钟。572多少分钟一趟? 阅读长相思,认选一个人物进行外貌描写及概述一个相关事件 100字,跪求!我没看过老湿叫写了 唐朝李白是男是女 小学语文五年级的古诗题,急!!! 契税有违约金吗 如何评价宋妍霏? 宋妍霏爸爸是哪里人? 接触到被隐翅虫咬的人身上的伤口、皮肤溃烂处会被传染吗? 被隐翅虫咬了会传染吗 滁州学院一共有多少个系?每个系又有多少个专业?最好的专业是什么? 滁州学院老区有哪些专业 滁州学院什么专业最好 风水上坐北朝南到底是什么意思