题目描述
又到暑假啦,Conan, Ayumi, Mitsuhiko, Genta一起到Hakase家愉快玩耍(然而你却不行……)。
Ayumi, Mitsuhiko, Genta依次开始画正方形(显然Ai是不会参加这个活动的),一人一笔,画完一个,以上一个正方形四边中点为顶点接着画啊画啊画啊……最后一共画了k个正方形。最终他们想知道自己各画了多长。
【样例解释】
输入
输入一行包含两个整数N,K,分别表示第一个正方形的边长,正方形个数。
输出
输出一行,三个实数,分别表示Ayumi, Mitsuhiko, Genta画的长度,答案保留3位小数。
输入样例复制
100 2
输出样例复制
270.711 241.421 170.711
说明
【数据规模与约定】
对于100%的数据满足,。
思路:模拟,用勾股定理求斜边的距离,因为斜边的那个点刚好把直边一分为二,所以就是边长/2,在套勾股定理就可以了,还有,画边顺序是a->b->c,所以模3+1.
代码:
#include<cstdio>
#include<cmath>
#include<iostream>
using namespace std;
double a[10],xb;
int n,k;
int main()
{scanf("%lf%d",&xb,&n);
for (int i=1;i<=n;++i)
{
k=k%3+1;//顺序。
a[1]+=xb;//a
a[2]+=xb;//b
a[3]+=xb;//c
a[k]+=xb;//最后的。
xb=sqrt((xb/2)*(xb/2)*2);//勾股。
}
printf("%.3lf %.3lf %.3lf",a[1],a[2],a[3]);//输出。
}