UVA 476 杂题

题意:判断点是否在矩形内。

分析:按题意写思路即可,注意输入。

注意:
1.判断点 的那个数组需要够大10000。否则会 Runtime_Error。
2.下面的参考代码,不完全符合面向对象的思路。(初学 面向对象)

题目

UVA 476 杂题
UVA 476 杂题

代码:

#include <iostream>
using namespace std;
class rec
{
private:
    double XLU,YLU,XRD,YRD;
public:
    void  setxy(double xLU,double yLU,double xRD,double yRD)
    {
        XLU=xLU;
        YLU=yLU;
        XRD=xRD;
        YRD=yRD;
    }
    int judge(double x,double y)
    {
        if(x>XLU && x<XRD && y>YRD &&y<YLU)
        {

            return 1;
        }
        else return 0;
    }
};
int main()
{
    char ch;int i;
    int numofrec=0;
    rec z;
    double a[10][4];
    double jud[10000][2]={0};

    while(cin>>ch,ch=='r'&&ch!='*')
    {
        numofrec++;
        for( i=0; i<4; i++)
        {
            cin>>a[numofrec-1][i];
        }

    }
    i=-1;
        do
        {
            i++;
            cin>>jud[i][0]>>jud[i][1];
        }
        while(jud[i][0]!=9999.9 && jud[i][1]!=9999.9);


        for(int k=0; k<i; k++)
        {
            int flag=0;int tfind=0;

            for(int j=0; j<numofrec; j++)
            {
                z.setxy(a[j][0],a[j][1],a[j][2],a[j][3]);
                flag=z.judge(jud[k][0],jud[k][1]);
                if(flag==1)
                {
                    cout<<"Point "<<k+1<<" is contained in figure "<<j+1<<endl;tfind=1;
                }
            }
            if(tfind==0) cout<<"Point "<<k+1<<" is not contained in any figure"<<endl;
        }
    return 0;
}