UVA 476 杂题
题意:判断点是否在矩形内。
分析:按题意写思路即可,注意输入。
注意:
1.判断点 的那个数组需要够大10000。否则会 Runtime_Error。
2.下面的参考代码,不完全符合面向对象的思路。(初学 面向对象)
题目
代码:
#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;
}