ganmu


私信TA

用户名:dotcpp0726067

访问量:1604

签 名:

等  级
排  名 1779
经  验 2563
参赛次数 0
文章发表 100
年  龄 0
在职情况 学生
学  校
专  业

  自我简介:

TA的其他文章

解题思路:

注意事项:

参考代码:

#include<iostream>

using namespace std;

#include<math.h>//调用数学库函数

//使用三角函数注意事项:

//1、包含头文件

//2、角度转弧度:输入的角度*PI/180  (PI为:acos(-1.0))

//即:输入的角度*acos(-1.0)/180

//此时求出的即为弧度,可直接使用

int main()

{

double l, w, x, y, r, a, v, s;//定义出要输入的各值

l = w = x = y = r = a = v = s = 0;

double journeyx = 0;//定义x方向总路程

double journeyy = 0;//定义y方向总路程

double lx, vx, wy, vy;

while (cin >> l >> w >> x >> y >> r >> a >> v >> s)

{

if (l == 0 && w == 0 && x == 0 && y == 0 && r == 0 && a == 0 && v == 0 && s == 0)break;//满足退出条件时退出

//在x轴方向

lx = l - 2 * r;//变化后的长度

vx = v * cos(a * acos(-1.0) / 180);//变化后的速率

journeyx = fabs(vx * s + x - r);//变化后的路程(距原点)(绝对值)

//在y轴方向

wy = w - 2 * r;

vy = v * sin(a * acos(-1.0) / 180);

journeyy = fabs(vy * s + y - r);

//x轴方向上的坐标

for (; journeyx > lx * 2;)

journeyx -= lx * 2;

if (journeyx > lx)

journeyx = lx - (journeyx - lx);

else if (journeyx <= lx)

journeyx;

//y轴方向上的坐标

for (; journeyy > wy * 2;)

journeyy -= wy * 2;

if (journeyy > wy)

journeyy = wy - (journeyx - wy);

else if (journeyy <= wy)

journeyy;

//最终坐标

journeyx += r;

journeyy += r;

printf("%.2lf %.2lf\n", journeyx, journeyy);

}

return 0;

}


 

0.0分

0 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换

万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区