7-36 复数四则运算(15 分)

7-36

7-36 复数四则运算(15 分)

本题要求编写程序,计算2个复数的和、差、积、商。

输入格式:

输入在一行中按照a1 b1 a2 b2的格式给出2个复数C1=a1+b1i和C2=a2+b2i的实部和虚部。题目保证C2不为0。

输出格式:

分别在4行中按照(a1+b1i) 运算符 (a2+b2i) = 结果的格式顺序输出2个复数的和、差、积、商,数字精确到小数点后1位。如果结果的实部或者虚部为0,则不输出。如果结果为0,则输出0.0。

输入样例1:

2 3.08 -2.04 5.06

输出样例1:

(2.0+3.1i) + (-2.0+5.1i) = 8.1i
(2.0+3.1i) - (-2.0+5.1i) = 4.0-2.0i
(2.0+3.1i) * (-2.0+5.1i) = -19.7+3.8i
(2.0+3.1i) / (-2.0+5.1i) = 0.4-0.6i

输入样例2:

1 1 -1 -1.01

输出样例2:

(1.0+1.0i) + (-1.0-1.0i) = 0.0
(1.0+1.0i) - (-1.0-1.0i) = 2.0+2.0i
(1.0+1.0i) * (-1.0-1.0i) = -2.0i
(1.0+1.0i) / (-1.0-1.0i) = -1.0

AC代码

#include<stdio.h>//特别
#include <math.h>
#define ZERO 0.1
double a1,b1,a2,b2;
double a3,b3;
int show(double a,double b,int c);
int he(){
    a3=a1+a2;
    b3=b1+b2;
    printf("(");
    show(a1,b1,0);
    printf(") ");
    printf("+");//运算符
    printf(" (");
    show(a2,b2,0);
    printf(") = ");
    show(a3,b3,1);
    return 0;
}
int cha(){
    a3=a1-a2;
    b3=b1-b2;
    printf("(");
    show(a1,b1,0);
    printf(") ");
    printf("-");//运算符
    printf(" (");
    show(a2,b2,0);
    printf(") = ");
    show(a3,b3,1);
    return 0;
}
int ji(){
    a3=a1*a2-b1*b2;
    b3=a1*b2+a2*b1;
    printf("(");
    show(a1,b1,0);
    printf(") ");
    printf("*");//运算符
    printf(" (");
    show(a2,b2,0);
    printf(") = ");
    show(a3,b3,1);
    return 0;
}
int shang(){
    a3=(a1*a2+b1*b2)/(a2*a2+b2*b2);
    b3=(-a1*b2+a2*b1)/(a2*a2+b2*b2);
    printf("(");
    show(a1,b1,0);
    printf(") ");
    printf("/");//运算符
    printf(" (");
    show(a2,b2,0);
    printf(") = ");
    show(a3,b3,1);
    return 0;
}

int show(double a,double b,int c){//遇到浮点数比较误差了
//通过相减之差是否足够接近零来判断是否相等
//不相等的话直接用大于号小于号判断大小
//精度丢失跟大于小于一点关系都没有。
//第三个测试点纯实数运算,当虚部等于零的时候输出时前面也要加正号!!
//注意结果和运算初值显示还是不同的 ,这个题目提醒我,题目要循着某种规律才能做对,
//一般人会把初值和结果分开 ,还是题意理解的问题,初值是否和结果遵循同样的显示手段 

    int flag=0;
    if (c && fabs(a)<ZERO && fabs(b)<ZERO)
    {
        printf("0.0");
        return 0;
    }
    if(c && fabs(a)>=ZERO){//a!=0
        flag=1;
        printf("%.1f", a);
    }
    if(c && fabs(b)>=ZERO){
        if(flag && b>0)
        printf("+%.1fi", b);
        else
        printf("%.1fi", b);
    }
    if(c!=1){
        printf("%.1f", a);
        if(b<0)
        printf("%.1fi", b);
        else
        printf("+%.1fi", b);
    }
    return 0;
}
int main(){//用结构体的时候?确实不愿意搞复杂,正如某些引入栈的题解,当然算法就是要拿来用的
    scanf("%lf %lf %lf %lf",&a1,&b1,&a2,&b2);//读入4个字符
    //要确保输出格式 ,如果结果的实部或者虚部为0,则不输出。题目只保证C2不为0
//如果结果为0,则输出0.0。
    he();
    printf("\n");
    cha();
    printf("\n");
    ji();
    printf("\n");
    shang();
    return 0;
}

原文地址:https://www.cnblogs.com/lingr7/p/9275956.html

时间: 2024-07-31 07:57:58

7-36 复数四则运算(15 分)的相关文章

结构-06. 复数四则运算(15)

1 #include <cstdio> 2 #include <cmath> 3 #define EPS 1e-1 4 5 void print1(double a,double b,double c,double d,char op) 6 { 7 printf("(%.1f%+.1fi) %c (%.1f%+.1fi) = ",a,b,op,c,d); 8 } 9 10 void print2(double a,double b) 11 { 12 if(fab

*结构-06. 复数四则运算

1 /* 2 * Main.c 3 * F6-结构-06. 复数四则运算 4 * Created on: 2014年8月26日 5 * Author: Boomkeeper 6 ********部分通过*********** 7 */ 8 9 #include <stdio.h> 10 #include <math.h> 11 12 #define EPSINON 0.1 13 14 /* 15 * 复数结构体,c1.c2对应于题目中的c1.c2 16 */ 17 struct c

蓝桥杯 算法提高 6-17 复数四则运算

算法提高 6-17复数四则运算 时间限制:1.0s   内存限制:512.0MB 设计复数库,实现基本的复数加减乘除运算. 输入时只需分别键入实部和虚部,以空格分割,两个复数之间用运算符分隔:输出时按a+bi的格式在屏幕上打印结果.参加样例输入和样例输出. 注意考虑特殊情况,无法计算时输出字符串"error". 样例输入 2 4 * -3 2 样例输出 -14-8i 样例输入 3 -2 + -1 3 样例输出 2+1i 1 #include<iostream> 2 #inc

7-36 复数四则运算

7-36 复数四则运算(15 分) 本题要求编写程序,计算2个复数的和.差.积.商. 输入格式: 输入在一行中按照a1 b1 a2 b2的格式给出2个复数C1=a1+b1i和C2=a2+b2i的实部和虚部.题目保证C2不为0. 输出格式: 分别在4行中按照(a1+b1i) 运算符 (a2+b2i) = 结果的格式顺序输出2个复数的和.差.积.商,数字精确到小数点后1位.如果结果的实部或者虚部为0,则不输出.如果结果为0,则输出0.0. 输入样例1: 2 3.08 -2.04 5.06 输出样例1

PAT 乙级 1091 N-自守数 (15 分)

1091 N-自守数 (15 分) 如果某个数 K 的平方乘以 N 以后,结果的末尾几位数等于 K,那么就称这个数为"N-自守数".例如 3×92?2??=25392,而 25392 的末尾两位正好是 92,所以 92 是一个 3-自守数. 本题就请你编写程序判断一个给定的数字是否关于某个 N 是 N-自守数. 输入格式: 输入在第一行中给出正整数 M(≤20),随后一行给出 M 个待检测的.不超过 1000 的正整数. 输出格式: 对每个需要检测的数字,如果它是 N-自守数就在一行中

1061 判断题 (15 分)

题目:1061 判断题 (15 分) 判断题的评判很简单,本题就要求你写个简单的程序帮助老师判题并统计学生们判断题的得分. 输入格式: 输入在第一行给出两个不超过 100 的正整数 N 和 M,分别是学生人数和判断题数量.第二行给出 M 个不超过 5 的正整数,是每道题的满分值.第三行给出每道题对应的正确答案,0 代表“非”,1 代表“是”.随后 N 行,每行给出一个学生的解答.数字间均以空格分隔. 输出格式: 按照输入的顺序输出每个学生的得分,每个分数占一行. 输入样例: 3 6 2 1 3

pta 数据结构 习题2.4 递增的整数序列链表的插入(15 分)

习题2.4 递增的整数序列链表的插入(15 分) 本题要求实现一个函数,在递增的整数序列链表(带头结点)中插入一个新整数,并保持该序列的有序性. 函数接口定义: List Insert( List L, ElementType X ); 其中List结构定义如下: typedef struct Node *PtrToNode; struct Node { ElementType Data; /* 存储结点数据 */ PtrToNode Next; /* 指向下一个结点的指针 */ }; type

PAT-JAVA-5-2 然后是几点 (15分)

5-2 然后是几点   (15分) 有时候人们用四位数字表示一个时间,比如1106表示11点零6分.现在,你的程序要根据起始时间和流逝的时间计算出终止时间. 读入两个数字,第一个数字以这样的四位数字表示当前时间,第二个数字表示分钟数,计算当前时间经过那么多分钟后是几点,结果也表示为四位数字.当小时为个位数时,没有前导的零,即5点30分表示为530.注意,第二个数字表示的分钟数可能超过60,也可能是负数. 输入格式: 输入在一行中给出2个整数,分别是四位数字表示的起始时间.以及流逝的分钟数,其间以

1001 害死人不偿命的(3n+1)猜想 (15)(15 分)

1001 害死人不偿命的(3n+1)猜想 (15)(15 分) 卡拉兹(Callatz)猜想: 对任何一个自然数n,如果它是偶数,那么把它砍掉一半:如果它是奇数,那么把(3n+1)砍掉一半.这样一直反复砍下去,最后一定在某一步得到n=1.卡拉兹在1950年的世界数学家大会上公布了这个猜想,传说当时耶鲁大学师生齐动员,拼命想证明这个貌似很傻很天真的命题,结果闹得学生们无心学业,一心只证(3n+1),以至于有人说这是一个阴谋,卡拉兹是在蓄意延缓美国数学界教学与科研的进展-- 我们今天的题目不是证明卡