习题9-3 平面向量加法 (15 分) | PAT

题目

本题要求编写程序,计算两个二维平面向量的和向量。

输入格式:
输入在一行中按照“x1 y1 x2 y2​​ ”的格式给出两个二维平面向量v​1=(x​1 ,y​1​​ )和v​2​​ =(x​2​​ ,y2​​ )的分量。

输出格式:
在一行中按照(x, y)的格式输出和向量,坐标输出小数点后一位(注意不能输出−0.0)。

输入样例:

3.5 -2.7 -13.9 8.7

输出样例:

(-10.4, 6.0)

分析

这道题核心思路是简单的,两个浮点数相加,测试点在于输出,不能输出成-0.0

abs 和 fabs

在C语言中 abs 是整数取绝对值, fabs 是浮点数取绝对值。

函数原型:

int abs(int x)
double fabs(double x)

一个浮点数的值在(-0.05,0.05)区间的数值,保留1位小数输出,会四舍五入到 -0.0 和 0.0,所以需要用fabs把他的值转换成0.0,达到规避输出 -0.0的目标。

题解

#include <stdio.h>

int main()
{
	double x1, x2, y1, y2, x, y;
	scanf("%lf %lf %lf %lf", &x1, &y1, &x2, &y2);
	x = x1 + x2;
	y = y1 + y2;

	if (fabs(x) < 0.05)
		x = 0.0;
	if (fabs(y) < 0.05)
		y = 0.0;

	printf("(%.1f, %.1f)", x, y);
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JoyCheung-

赏颗糖吃吧~~~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值