B1051 复数乘法(15 分)
【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 分)的更多相关文章
- PAT Basic 1051 复数乘法 (15 分)
复数可以写成 ( 的常规形式,其中 A 是实部,B 是虚部,i 是虚数单位,满足 1:也可以写成极坐标下的指数形式 (,其中 R 是复数模,P 是辐角,i 是虚数单位,其等价于三角形式 (. 现给定两 ...
- 1051 复数乘法 (15 分)C语言
复数可以写成 (A+Bi) 的常规形式,其中 A 是实部,B 是虚部,i 是虚数单位,满足 i^2=−1:也可以写成极坐标下的指数形式 (R×e(Pi) ),其中 R 是复数模,P 是辐角,i ...
- PAT-乙级-1051. 复数乘法 (15)
1051. 复数乘法 (15) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 复数可以写成(A + Bi)的常规 ...
- PAT 乙级 1091 N-自守数 (15 分)
1091 N-自守数 (15 分) 如果某个数 K 的平方乘以 N 以后,结果的末尾几位数等于 K,那么就称这个数为“N-自守数”.例如 3×922=25392,而 25392 的末尾两位正好是 ...
- PAT 乙级 1086 就不告诉你 (15 分)
1086 就不告诉你 (15 分) 做作业的时候,邻座的小盆友问你:“五乘以七等于多少?”你应该不失礼貌地围笑着告诉他:“五十三.”本题就要求你,对任何一对给定的正整数,倒着输出它们的乘积. 输入格式 ...
- PTA 7-3 jmu-ds-单链表的基本运算(15 分)
jmu-ds-单链表的基本运算(15 分) 实现单链表的基本运算:初始化.插入.删除.求表的长度.判空.释放.(1)初始化单链表L,输出L->next的值:(2)依次采用尾插法插入元素:输入分两 ...
- PAT 乙级 1071 小赌怡情(15 分)
1071 小赌怡情(15 分) 常言道“小赌怡情”.这是一个很简单的小游戏:首先由计算机给出第一个整数:然后玩家下注赌第二个整数将会比第一个数大还是小:玩家下注 t 个筹码后,计算机给出第二个数.若玩 ...
- PAT 乙级 1051 复数乘法 (15) C++版
1051. 复数乘法 (15) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 复数可以写成(A + Bi)的常规 ...
- 求交错序列前N项和(15 分)
7-2 求交错序列前N项和(15 分) 本题要求编写程序,计算交错序列 1-2/3+3/5-4/7+5/9-6/11+... 的前N项之和. 输入格式: 输入在一行中给出一个正整数N. 输出格式: 在 ...
随机推荐
- jquery--实现类似淘宝星星评分功能
- 不正之处,欢迎指正.^-^.好绕的话 贴码.html <body> <div id="div"> <ul> <li>☆< ...
- 基于HttpClient的新版正方教务系统模拟登录及信息获取API
简介 通过HttpClient获取网页数据源,通过Jsoup解析数据.先模拟登录,再获取信息.模拟浏览器正常操作,封装请求头信息获取SESSIONID.模拟登录成功后切勿断开会话,依赖登录请求得到的C ...
- C#---vs2010发布、打包安装程序程序(转载)
转载地址:点击打开 1. 在vs2010 选择“新建项目”→“ 其他项目类型”→“ Visual Studio Installer→“安装项目”: 命名为:Setup1 . 这是在VS2010中将有三 ...
- hibernate课程 初探单表映射2-6 session详解(下)
本节主要内容: 1 介绍了getCurrentSession和opensession的区别 2 demo:通过打印比较两个session是否相同,验证两个session是否是同一session 3 d ...
- 进程的基础理论、并发(multiprocessing模块)
一.粘包优化方案 之前我们解决粘包的方式是用struct模块来制作一个报头,但是这个解决的方案是有漏洞的,当我们需要传送的文件大于2g时将会报错.所以我们今天将用json来制作报头. from soc ...
- 50道CSS基础面试题(附答案)
1 介绍一下标准的CSS的盒子模型?与低版本IE的盒子模型有什么不同的? 标准盒子模型:宽度=内容的宽度(content)+ border + padding + margin低版本IE盒子模型:宽度 ...
- eclipse, idea安装lombok插件
参考博客: https://www.cnblogs.com/quan-coder/p/8387040.html 一:在开发工具中安装插件: Eclipse: 下载地址:https://projectl ...
- 在SQL中查看文件组中有哪些表
SELECT o.[name], o.[type], i.[name], i.[index_id], f.[name] FROM sys.indexes i INNER JOIN sys.filegr ...
- 交互ajax
原生的js封装ajax1.创建ajax对象var oAjax=new XMLHttpRequest();//不兼容IE6var oAjax=new ActiveXobject('Microsoft.X ...
- linux 命令——16 which(转)
我们经常在linux要查找某个文件,但不知道放在哪里了,可以使用下面的一些命令来搜索: which 查看可执行文件的位置. whereis 查看文件的位置. ...