zoukankan      html  css  js  c++  java
  • 算法笔记_162:算法提高 复数归一化(Java)

    目录

    1 问题描述

    2 解决方案

     


    1 问题描述

    编写函数Normalize,将复数归一化,即若复数为a+bi,归一化结果为a/sqrt(a*a+b*b) + i*b/sqrt(a*a+b*b) 。使用结构体指针类型作为函数参数可能是必要的。其中实部和虚部由键盘输入,输出为归一化结果,如果归一化结果的实部或虚部为小数的要求保留一位小数。
    

    样例输入:(格式说明:3 4 分别为以空格隔开的实数的实部和虚部)
    3 4
    样例输出:
    0.6+0.8i
    样例输入: 
    2 5
    样例输出:
    0.4+0.9i

    2 解决方案

    具体代码如下:

    import java.util.Scanner;
    
    public class Main {
        
        public void Normaliz(double a, double b) {
            double c = Math.sqrt(a*a + b*b);
            if(a % c != 0) {
                a = a / c;
                System.out.printf("%.1f", a);
            } else {
                a = a / c;
                int a1 = (int) a;
                System.out.print(a1);
            }
            if(b > 0)
                System.out.print("+");
            if(b % c != 0) {
                b = b / c;
                System.out.printf("%.1f", b);
            } else {
                b = b / c;
                int b1 = (int) b;
                System.out.print(b1);
            }
            System.out.print("i");
        }
        
        public static void main(String[] args) {
            Main test = new Main();
            Scanner in = new Scanner(System.in);
            double a = in.nextDouble();
            double b = in.nextDouble();
            test.Normaliz(a, b);
        }
    }
  • 相关阅读:
    大数板子
    数位dp
    BM算法
    牛客小白月赛7
    划分树
    可持久化线段树
    素数
    一些数学公式
    线性基
    ConcurrentHashMap 并发HashMap原理分析
  • 原文地址:https://www.cnblogs.com/liuzhen1995/p/6785663.html
Copyright © 2011-2022 走看看