搬圆桌问题

现在有一张半径为r的圆桌,其中心位于(x,y),现在他想把圆桌的中心移到(x1,y1)。每次移动一步,都必须在圆桌边缘固定一个点然后将圆桌绕这个点旋转。问最少需要移动几步。

输入描述:
一行五个整数r,x,y,x1,y1(1≤r≤100000,-100000≤x,y,x1,y1≤100000)


输出描述:
输出一个整数,表示答案

输入例子:
2 0 0 0 4

输出例子:
1

 

问题解析

圆盘在旋转的过程中,圆心最大的移动距离为直径  ;最小移动的距离为0;所以

移动的步数 = 两圆心的距离-直径

 

代码

//#include "stdafx.h"
#include <iostream>
#include <string>
#include <vector>
#include <math.h>
#include<stack>
#include <stdio.h>
//#include <conio.h>
#include <stdlib.h>
#include <time.h>
using namespace std;




#include <stdio.h>


int f(double r,double x,double y,double x1,double y1)
{
    double x2 ;
    double y2;
    x2 = x1-x;
    y2 = y1-y;
    
    double d;
    d = sqrt(x2*x2+y2*y2);
    
    int ret = 0;
    ret =(int) d/(2*r);
    return ret;
    
    
}




int main()
{
   double r;
   double x;
   double y;
   double x1;
   double y1;
    
    
    while(cin>>r>>x>>y>>x1>>y1)
    {
         int s = 0;
    s = f(r,x,y,x1,y1);
    
    cout << s << endl;    
        
    }
    
    
   
    return 0;    
    
}

当然了,头文件存在没有使用的情况。

 

posted @ 2017-03-30 16:55  china_sdd  阅读(155)  评论(0编辑  收藏  举报