鱼C论坛

 找回密码
 立即注册
查看: 1469|回复: 6

[已解决]数学编程题

[复制链接]
发表于 2022-3-19 21:01:08 | 显示全部楼层 |阅读模式
20鱼币
函数 main() 接收两个表示从坐标原点出发的二维向量的元组 vector1 和 vector2,

例如 (3,0) 表示从坐标原点 (0, 0) 到坐标 (3, 0) 的向量,

要求返回两个向量 vector1 和 vector2 的夹角(单位为度,数值大小在 0 到 180 之间),

并且要求结果恰好保留 2 位小数,例如向量 (3, 0) 和 (0, 4) 的夹角为 90.00。

删除下面代码中的 pass 语句,替换为自己的代码,完成要求的功能。

代码已导入的标准库对象不是必须使用的,可以自己决定是否使用。

  1. from operator import mul
  2. from math import acos, degrees

  3. def main(vector1, vector2):
  4.     pass
复制代码
最佳答案
2022-3-19 21:01:09
嗯,上面的代码不对,还得考虑点在第几象限的问题,我再想一想

  1. $ cat main.py
  2. #!/usr/bin/env python
  3. #coding=utf-8

  4. from math import sqrt, pow, acos, fabs, degrees

  5. def angle(A, B):
  6.     c = sqrt(pow(A[0], 2) + pow(A[1], 2))
  7.     n = 90 - degrees(acos(A[1] / c))
  8.     c = sqrt(pow(B[0], 2) + pow(B[1], 2))
  9.     m = 90 - degrees(acos(B[1] / c))
  10.     n = n if A[0] >= 0 else (90 - n) * 2 + n
  11.     m = m if B[0] >= 0 else (90 - m) * 2 + m
  12.     return fabs(n - m)

  13. print(angle((3, 9), (4, 5)))
  14. print(angle((3, 0), (0, 4)))
  15. print(angle((-3, 9), (4, 5)))
  16. print(angle((3, 0), (0, -4)))
  17. $ ./main.py
  18. 20.224859431168056
  19. 90.0
  20. 57.094757077012105
  21. 90.0
  22. $
复制代码


1.png

最佳答案

查看完整内容

嗯,上面的代码不对,还得考虑点在第几象限的问题,我再想一想
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-3-19 21:01:09 | 显示全部楼层    本楼为最佳答案   
嗯,上面的代码不对,还得考虑点在第几象限的问题,我再想一想

  1. $ cat main.py
  2. #!/usr/bin/env python
  3. #coding=utf-8

  4. from math import sqrt, pow, acos, fabs, degrees

  5. def angle(A, B):
  6.     c = sqrt(pow(A[0], 2) + pow(A[1], 2))
  7.     n = 90 - degrees(acos(A[1] / c))
  8.     c = sqrt(pow(B[0], 2) + pow(B[1], 2))
  9.     m = 90 - degrees(acos(B[1] / c))
  10.     n = n if A[0] >= 0 else (90 - n) * 2 + n
  11.     m = m if B[0] >= 0 else (90 - m) * 2 + m
  12.     return fabs(n - m)

  13. print(angle((3, 9), (4, 5)))
  14. print(angle((3, 0), (0, 4)))
  15. print(angle((-3, 9), (4, 5)))
  16. print(angle((3, 0), (0, -4)))
  17. $ ./main.py
  18. 20.224859431168056
  19. 90.0
  20. 57.094757077012105
  21. 90.0
  22. $
复制代码


1.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-3-19 22:53:24 | 显示全部楼层
本帖最后由 人造人 于 2022-3-19 22:54 编辑

不知道有没有漏掉一些特殊情况,多给几组输入输出看看

  1. $ cat main.py
  2. #!/usr/bin/env python
  3. #coding=utf-8

  4. from math import sqrt, pow, acos, fabs, degrees

  5. def angle(A, B):
  6.     c = sqrt(pow(A[0], 2) + pow(A[1], 2))
  7.     n = acos(A[1] / c)
  8.     c = sqrt(pow(B[0], 2) + pow(B[1], 2))
  9.     m = acos(B[1] / c)
  10.     x = fabs(n - m)
  11.     return degrees(x)

  12. print(angle((3, 9), (4, 5)))
  13. print(angle((3, 0), (0, 4)))
  14. print(angle((-3, 9), (4, 5)))
  15. print(angle((3, 0), (0, -4)))
  16. $ ./main.py
  17. 20.224859431168067
  18. 90.0
  19. 20.224859431168067
  20. 90.0
  21. $
复制代码


1.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-3-19 23:28:21 | 显示全部楼层
人造人 发表于 2022-3-19 22:53
不知道有没有漏掉一些特殊情况,多给几组输入输出看看


非常感谢大佬,但是有两组数据不通过,再看看是什么问题呗,

我不懂这个反余弦函数

e.PNG
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-3-19 23:49:30 | 显示全部楼层
人造人 发表于 2022-3-19 21:01
嗯,上面的代码不对,还得考虑点在第几象限的问题,我再想一想


谢谢大佬,可以了,可以说说这道题的思路是怎样的吗?

反余弦是哪条边比哪条边呀,这数学好让人凌乱呀
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-3-19 23:56:03 | 显示全部楼层
isdkz 发表于 2022-3-19 23:49
谢谢大佬,可以了,可以说说这道题的思路是怎样的吗?

反余弦是哪条边比哪条边呀,这数学好让人凌乱 ...

https://baike.baidu.com/item/%E4 ... /4374733?fr=aladdin

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-3-20 00:03:21 | 显示全部楼层
人造人 发表于 2022-3-19 23:56
https://baike.baidu.com/item/%E4%B8%89%E8%A7%92%E5%87%BD%E6%95%B0%E5%85%AC%E5%BC%8F/4374733?fr=ala ...

好的,谢谢大佬
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-22 03:41

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表