zoukankan      html  css  js  c++  java
  • [编程题-网易] 炮台攻击

    [编程题-网易] 炮台攻击

    兰博教训提莫之后,然后和提莫讨论起约德尔人,谈起约德尔人,自然少不了一个人,那 就是黑默丁格------约德尔人历史上最伟大的科学家. 提莫说,黑默丁格最近在思考一个问题:黑默丁格有三个炮台,炮台能攻击到距离它R的敌人 (两点之间的距离为两点连续的距离,例如(3,0),(0,4)之间的距离是5),如果一个炮台能攻击 到敌人,那么就会对敌人造成1×的伤害.黑默丁格将三个炮台放在N*M方格中的点上,并且给出敌人 的坐标. 问:那么敌人受到伤害会是多大?

    输入描述:
    第一行9个整数,R,x1,y1,x2,y2,x3,y3,x0,y0.R代表炮台攻击的最大距离,(x1,y1),(x2,y2),
    (x3,y3)代表三个炮台的坐标.(x0,y0)代表敌人的坐标.



    输出描述:
    输出一行,这一行代表敌人承受的最大伤害,(如果每个炮台都不能攻击到敌人,输出0×)
    输入例子:
    1 1 1 2 2 3 3 1 2
    输出例子:
    2x
    #include<iostream>
    #include<vector>
    using namespace std;
    int main()
    {
        double r;
        while(cin>>r)
        {
            vector<vector<double>> locs;
            for(int i=0;i<4;i++)
            {
                vector<double> loc;
                double x,y;
                cin>>x;
                cin>>y;
                loc.push_back(x);
                loc.push_back(y);
                locs.push_back(loc);
            }
            int cnt=0;
            for(int i=0;i<3;i++)
            {
                double dd=(locs[i][0]-locs[3][0])*(locs[i][0]-locs[3][0])+(locs[i][1]-locs[3][1])*(locs[i][1]-locs[3][1]); 
                if(dd<=r*r)
                    cnt++;
            }
            cout<<cnt<<'x'<<endl;
        }
    }
  • 相关阅读:
    NDK中使用pthread多线程中自己写的一个BUG
    Android Native crash日志分析
    Android细笔记--DataStorage
    求二叉树第n层节点数
    对YUV数据进行裁剪
    Android XML中引用自定义内部类view的四个why
    Android细笔记--ContentProvider
    Android Log Tag含义
    189-RotaeArray
    二分查找法
  • 原文地址:https://www.cnblogs.com/learning-c/p/5741278.html
Copyright © 2011-2022 走看看