Java에서 복수형을 정의하는 방법은 무엇입니까?
java는 복소수에 대한 수학 연산을 수행하기 위해 복소수 클래스를 생성합니다. 복소수 형식은 RealPart+ImaginaryPart*i입니다. 여기서 i는 -1의 제곱근입니다.
(1) 부동 소수점 변수 사용 이 클래스의 비공개 데이터를 나타냅니다. 두 개의 생성자가 제공됩니다. 하나는 이러한 유형의 선언이 이루어질 때 개체를 초기화하는 데 사용되며, 다른 하나는 기본값이 있는 매개 변수 없는 생성자입니다.
(2) 두 복소수의 덧셈, 뺄셈, 곱셈을 위한 연산 방법을 제공합니다.
(3) (a,b) 형식으로 복소수를 인쇄합니다. 여기서 a는 실수부이고 b는 허수부입니다.
Java 코드는 다음과 같습니다.
public class ComplexNumber implements Cloneable { private double realPart; //复数的实部 private double imaginaryPart; //复数的虚部 public ComplexNumber() { //默认构造函数 this.realPart = 0.0; this.imaginaryPart = 0.0; } public ComplexNumber(double a, double b) { //重载构造函数 this.realPart = a; this.imaginaryPart = b; } /** * 复数的加法运算 c = a + b的运算法则是: * c.实部 = a.实部 + b.实部 * c.虚部 = a.虚部 + b.虚部 */ public ComplexNumber add(ComplexNumber aComNum) { if (aComNum == null) { System.err.println("对象不能够为null!"); return new ComplexNumber(); } return new ComplexNumber(this.realPart + aComNum.getRealPart(), this.imaginaryPart + aComNum.getImaginaryPart()); } /** * 复数的减法运算 c = a - b的运算法则是: * c.实部 = a.实部 - b.实部 * c.虚部 = a.虚部 - b.虚部 */ public ComplexNumber decrease(ComplexNumber aComNum) { if (aComNum == null) { System.err.println("对象不能够为null!"); return new ComplexNumber(); } return new ComplexNumber(this.realPart - aComNum.getRealPart(), this.imaginaryPart - aComNum.getImaginaryPart()); } /** * 复数的乘法运算 c = a * b的运算法则是: * c.实部 = a.实部 * b.实部 - a.虚部 * b.虚部 * c.虚部 = a.虚部 * b.实部 + a.实部 * b.虚部 */ public ComplexNumber multiply(ComplexNumber aComNum) { if (aComNum == null) { System.err.println("对象不能够为null!"); return new ComplexNumber(); } double newReal = this.realPart * aComNum.realPart - this.imaginaryPart * aComNum.imaginaryPart; double newImaginary = this.realPart * aComNum.imaginaryPart + this.imaginaryPart * aComNum.realPart; ComplexNumber result = new ComplexNumber(newReal, newImaginary); return result; } /** * 复数的除法运算 c = a / b 的运算法则是: * c.实部 = (a.实部 * b.实部 + a.虚部 * b.虚部) / (b.实部* b.实部 + b.虚部 * b.虚部) * c.虚部 = (a.虚部 * b.实部 - a.实部 * b.虚部) / (b.实部 * b.实部 + b.虚部 * b.虚部) */ public ComplexNumber divide(ComplexNumber aComNum) { if (aComNum == null) { System.err.println("对象不能够为null!"); return new ComplexNumber(); } if ((aComNum.getRealPart() == 0) && (aComNum.getImaginaryPart() == 0)) { System.err.println("除数不能够为0!"); return new ComplexNumber(); } double temp = aComNum.getRealPart() * aComNum.getRealPart() + aComNum.getImaginaryPart() * aComNum.getImaginaryPart(); double crealpart = (this.realPart * aComNum.getRealPart() + this.imaginaryPart * aComNum.getImaginaryPart()) / temp; double cimaginaryPart = (this.imaginaryPart * aComNum.getRealPart() - this.realPart * aComNum.getImaginaryPart()) / temp; return new ComplexNumber(crealpart, cimaginaryPart); } public String toString() { //将一个复数显示为字符串 return this.realPart + " + " + this.imaginaryPart + "i"; } public boolean equals(Object obj) { //比较一个对象是否和这个复数对象的值相等 if (obj == null) { return false; } //首先判断a是不是一个复数对象,instanceof关键字是用来判断对象的类型 if (obj instanceof ComplexNumber) { //如果a是复数对象,需要将它强制类型转换成复数对象,才能调用复数类提供的方法 ComplexNumber b = (ComplexNumber) obj; if ((this.realPart == b.getRealPart()) && (this.imaginaryPart == b.getImaginaryPart())) { return true; } else { return false; } } else { return false; } } public int hashCode() { //获得该复数对象的hashcode /** * 如果两个复数对象是equals的,那么它们的hashCode也必须相同 * 两个值相等的复数对象通过toString()方法得到的输出字符串是一样的 * 于是,可以把得到的字符串的hashCode当作复数对象的hashCode */ return this.toString().hashCode(); } public Object clone() { //根据现有对象克隆一个新对象 /** * 如果要使自定义的类能够被clone,就必须实现Cloneable接口并且重写它的clone()方法 * 如果仅仅重写了clone方法而没有在类的声明中添加实现Cloneable接口 * 调用clone方法时将会出现CloneNotSupportedException异常 */ try { ComplexNumber newObject = (ComplexNumber) super.clone(); newObject.setRealPart(this.realPart); newObject.setImaginaryPart(this.imaginaryPart); return newObject; } catch (CloneNotSupportedException e) { //如果没有实现Cloneable接口,抛出异常 e.printStackTrace(); return null; } } public double getImaginaryPart() { //返回虚部 return imaginaryPart; } public void setImaginaryPart(double imaginaryPart) { //设置虚部 this.imaginaryPart = imaginaryPart; } public double getRealPart() { //返回实部 return realPart; } public void setRealPart(double realPart) { //设置实部 this.realPart = realPart; } public static void main(String[] args) throws CloneNotSupportedException { ComplexNumber a = new ComplexNumber(20, 15); ComplexNumber b = new ComplexNumber(11, 20); System.out.println("ComplexNumber a: " + a.toString()); System.out.println("ComplexNumber b: " + b.toString()); System.out.println("(a + b) = " + a.add(b).toString()); System.out.println("(a - b) = " + a.decrease(b).toString()); System.out.println("(a * b) = " + a.multiply(b).toString()); System.out.println("(a / b) = " + a.divide(b).toString()); } }
관련 학습 권장 사항: java 기본 튜토리얼
위 내용은 Java에서 복수형을 정의하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











이 기사는 2025 년에 상위 4 개의 JavaScript 프레임 워크 (React, Angular, Vue, Svelte)를 분석하여 성능, 확장 성 및 향후 전망을 비교합니다. 강력한 공동체와 생태계로 인해 모두 지배적이지만 상대적으로 대중적으로

Java의 클래스 로딩에는 부트 스트랩, 확장 및 응용 프로그램 클래스 로더가있는 계층 적 시스템을 사용하여 클래스로드, 링크 및 초기화 클래스가 포함됩니다. 학부모 위임 모델은 핵심 클래스가 먼저로드되어 사용자 정의 클래스 LOA에 영향을 미치도록합니다.

이 기사는 카페인 및 구아바 캐시를 사용하여 자바에서 다단계 캐싱을 구현하여 응용 프로그램 성능을 향상시키는 것에 대해 설명합니다. 구성 및 퇴거 정책 관리 Best Pra와 함께 설정, 통합 및 성능 이점을 다룹니다.

이 기사는 원격 코드 실행을 허용하는 중요한 결함 인 Snakeyaml의 CVE-2022-1471 취약점을 다룹니다. Snakeyaml 1.33 이상으로 Spring Boot 응용 프로그램을 업그레이드하는 방법에 대해 자세히 설명합니다.

Node.js 20은 V8 엔진 개선, 특히 더 빠른 쓰레기 수집 및 I/O를 통해 성능을 크게 향상시킵니다. 새로운 기능에는 더 나은 webAssembly 지원 및 정제 디버깅 도구, 개발자 생산성 및 응용 속도 향상이 포함됩니다.

대규모 분석 데이터 세트를위한 오픈 테이블 형식 인 Iceberg는 데이터 호수 성능 및 확장 성을 향상시킵니다. 내부 메타 데이터 관리를 통한 Parquet/Orc의 한계를 해결하여 효율적인 스키마 진화, 시간 여행, 동시 W를 가능하게합니다.

이 기사는 Lambda 표현식, 스트림 API, 메소드 참조 및 선택 사항을 사용하여 기능 프로그래밍을 Java에 통합합니다. 간결함과 불변성을 통한 개선 된 코드 가독성 및 유지 관리 가능성과 같은 이점을 강조합니다.

이 기사에서는 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 및 Gradle을 사용하여 접근 방식과 최적화 전략을 비교합니다.
