【PAT】B1051 复数乘法(15 分) - 路明天 - 博客园 https://www.cnblogs.com/hebust/p/9496809.html

在此对四舍五入输出结果做总结。

对于doublde 类型,int i = (int )(a+0.5),实现保留到个位的四舍五入,一般的“.2f”是四舍六入五成双的。

另外就是针对double的0的处理,要特别注意在0附近实现四舍五入。

    if (A + 0.005 >= 0 && A < 0)
printf("0.00");
else
printf("%.2f", A);
if(B >= 0)
printf("+%.2fi", B);
else if (B + 0.005 >= 0 && B < 0)
printf("+0.00i");
else
printf("%.2lfi", B);

B1051 复数乘法 (15分)

输入格式:

输入在一行中依次给出两个复数的R和P,数字间以空格分隔。

输出格式:

在一行中按照 A+Bi的格式输出两数乘积的常规形式,实部和虚部均保留 2 位小数。注意:如果 B 是负数,则应该写成 A-|B|i 的形式。

输入样例:

2.3 3.5 5.2 0.4

输出样例:

-8.68-8.23i

别人的AC代码

还要注意到用四舍五入的方法判断是否应该输出0.00

这个计算方法,比我的简单,我想要代码复用,反而造成了恶果。

保留两位小数

if (A + 0.005 >= 0 && A < 0)
printf("0.00");

为什么保留两位小数这么复杂,这里是若5则入,对0的符号,对0附近的数特别对待。

保留两位小数,.2lf使用的是,四舍六入五成双的规则。

要四舍五入,那么就用round函数,得到一个double 在强制转换int,就是整数位的四舍五入去掉小数部分,不如

int i = (int)(a+0.5)的技巧漂亮。

#include <math.h>
#include<stdio.h>
int main() {
double r1, p1, r2, p2, A, B;
scanf("%lf %lf %lf %lf",&r1,&p1,&r2,&p2);
r1*=r2;p1+=p2;
A = r1 * cos(p1);
B = r1 * sin(p1);
if (A + 0.005 >= 0 && A < 0)
printf("0.00");
else
printf("%.2f", A);
if(B >= 0)
printf("+%.2fi", B);
else if (B + 0.005 >= 0 && B < 0)
printf("+0.00i");
else
printf("%.2lfi", B);
return 0;
}

从这里的AC代码,得到的启示,或者说小知识,就是保留小数位的精度,输出,对于0附近的数要特别注意。要实现这里的四舍五入输出0.00或者0.000之类的,采用+0.005>=0 并且本身小于0,来实现四舍五入。

#include<cstdio>
#include<iostream>
#include<algorithm>
#include<math.h>
#include<cmath>
using namespace std; int main()
{
double R1, P1, R2, P2;
double a, b, c, d; cin >> R1 >> P1 >> R2 >> P2;
a = R1*cos(P1);
b = R1*sin(P1);
c = R2*cos(P2);
d = R2*sin(P2); double shi, xu;
shi = a*c - b*d;
xu = b*c + a*d;
if (abs(shi) < 0.001)
shi = 0;
if (abs(xu) < 0.001)
xu = 0; if (xu >= 0)
printf("%.2f+%.2fi", shi, xu);
else if (xu < 0)
printf("%.2f%.2fi", shi, xu); system("pause");
return 0;
}

作者:ad50468549

来源:CSDN

原文:https://blog.csdn.net/u011036919/article/details/66975447

版权声明:本文为博主原创文章,转载请附上博文链接!

	double shi, xu;
shi = a*c - b*d;
xu = b*c + a*d;
if (abs(shi) < 0.001)
shi = 0;
if (abs(xu) < 0.001)
xu = 0; if (xu >= 0)
printf("%.2f+%.2fi", shi, xu);
else if (xu < 0)
printf("%.2f%.2fi", shi, xu);

修改

	if (abs(shi) <= 0.004)
shi = 0;
if (abs(xu) <= 0.04)
xu = 0;

依然能够AC掉

改成0.1,有一个测试点过不去,所以那一个测试点,正是在考察对0的四舍五入

如果是-0.004,那么应该输出的是-0.00吗?

printf("%.2f", -0.004);

输出的是-0.00

printf("%.2f", -0.005);

这样输出的是-0.01,还是一样的四舍五入进位了。

但是这个进位是绝对值的进位(c++)和需要的对0处理不符合按照AC代码1,这里应输出0.00

B1051 复数乘法(15 分)的更多相关文章

  1. PAT Basic 1051 复数乘法 (15 分)

    复数可以写成 ( 的常规形式,其中 A 是实部,B 是虚部,i 是虚数单位,满足 1:也可以写成极坐标下的指数形式 (,其中 R 是复数模,P 是辐角,i 是虚数单位,其等价于三角形式 (. 现给定两 ...

  2. 1051 复数乘法 (15 分)C语言

    复数可以写成 (A+Bi) 的常规形式,其中 A 是实部,B 是虚部,i 是虚数单位,满足 i^​2=−1:也可以写成极坐标下的指数形式 (R×e​(Pi)​ ),其中 R 是复数模,P 是辐角,i ...

  3. PAT-乙级-1051. 复数乘法 (15)

    1051. 复数乘法 (15) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 复数可以写成(A + Bi)的常规 ...

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

    1091 N-自守数 (15 分) 如果某个数 K 的平方乘以 N 以后,结果的末尾几位数等于 K,那么就称这个数为“N-自守数”.例如 3×92​2​​=25392,而 25392 的末尾两位正好是 ...

  5. PAT 乙级 1086 就不告诉你 (15 分)

    1086 就不告诉你 (15 分) 做作业的时候,邻座的小盆友问你:“五乘以七等于多少?”你应该不失礼貌地围笑着告诉他:“五十三.”本题就要求你,对任何一对给定的正整数,倒着输出它们的乘积. 输入格式 ...

  6. PTA 7-3 jmu-ds-单链表的基本运算(15 分)

    jmu-ds-单链表的基本运算(15 分) 实现单链表的基本运算:初始化.插入.删除.求表的长度.判空.释放.(1)初始化单链表L,输出L->next的值:(2)依次采用尾插法插入元素:输入分两 ...

  7. PAT 乙级 1071 小赌怡情(15 分)

    1071 小赌怡情(15 分) 常言道“小赌怡情”.这是一个很简单的小游戏:首先由计算机给出第一个整数:然后玩家下注赌第二个整数将会比第一个数大还是小:玩家下注 t 个筹码后,计算机给出第二个数.若玩 ...

  8. PAT 乙级 1051 复数乘法 (15) C++版

    1051. 复数乘法 (15) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 复数可以写成(A + Bi)的常规 ...

  9. 求交错序列前N项和(15 分)

    7-2 求交错序列前N项和(15 分) 本题要求编写程序,计算交错序列 1-2/3+3/5-4/7+5/9-6/11+... 的前N项之和. 输入格式: 输入在一行中给出一个正整数N. 输出格式: 在 ...

随机推荐

  1. 如何让nginx支持ThinkPHP框架(重点参考)

    公司有一款即将上线的应用服务端是基于ThinkPHP写的,本地测试无异常,上传到外网服务器后无法连接.这可把我和我的小伙伴们吓死了,怎么回事儿,本地测试都是对的呀! 我和我的小伙伴们开始找原因,换了一 ...

  2. vulhub-php/php_inclusion_getshell

    注:本地测试php文件包含+phpinfo泄露导致getshell,此漏洞与php版本无关 使用vulhub环境进行复现: 项目地址:https://github.com/vulhub/vulhub/ ...

  3. Sublime Text插件列表

    本文由 伯乐在线 - 艾凌风 翻译,黄利民 校稿.英文出处:ipestov.com.欢迎加入翻译组. 本文收录了作者辛苦收集的Sublime Text最佳插件,很全. 最佳的Sublime Text ...

  4. Hibernate笔记2

    一.持久化类 1.持久化标识OID     数据库中叫做主键,对应实体的ID属性即为OID;Hibernate通过OID区分两个对象是否为同一对象;OID的生成一般交由程序自动处理; 2.持久化类   ...

  5. php编译安装过程中遇到问题

    编译安装PHP时遇到的问题 问题1: configure: error: xml2-config not found. Please check your libxml2 installation. ...

  6. Pylint 是什么

    Pylint 是什么 Pylint 是一个 Python 代码分析工具,它分析 Python 代码中的错误,查找不符合代码风格标准(Pylint 默认使用的代码风格是 PEP 8,具体信息,请参阅参考 ...

  7. 浅谈Scrum敏捷开发:4个输入/输出、3个关键物、3个会议

    文章对Scrum敏捷开发流程进行系统的分析,希望借此文能够加深你对敏捷开发的认知,更好的展开产品工作. Scrum敏捷开发,是一种敏捷开发框架,是一个增量的.迭代的开发过程,具备可视.可集成和可运行使 ...

  8. 有些其他程序设置为从 Outlook 下载并删除邮件。为防止发生此意外情况,我们将这些邮件放入一个特殊的 POP 文件夹中

    最近使用FOXMAIL接收MSN邮件时,发现有一些邮件收取不到,进到WEB页面,页面下方提示“你的邮件位于 POP 文件夹中!有些其他程序设置为从 Outlook 下载并删除邮件.为防止发生此意外情况 ...

  9. idea单元测试junit

    参考文章地址地址:http://blog.csdn.net/u011138533/article/details/52165577 本文按以下顺序讲解JUnit4的使用 下载jar包 单元测试初体验 ...

  10. C语言中的异常处理机制

    #define try if(!setjmp(Jump_Buffer)) 返回try现场后重新执行判断,所以有两次执行. http://blog.csdn.net/tian_dao_chou_qin/ ...