题目很简单嗷,单纯就是记录一下
用一个结构体放数据
如果小于0且为A,flagAs=1
如果大于0且为A,flagAb=1
如果小于0且为B,flagBs=1
如果大于0且为B,flagBb=1
两两判断值不同时为1
还可以改进的地方:
(1)判断AB哪个为正哪个为负的方法有待简化
(2)判断是否全都满足情况有待简化
#include<bits/stdc++.h>
using namespace std;
struct dian
{
int x;
int y;
char type;
}di[1010];
int main()
{
int n=0,m=0;
cin>>n>>m;
for(int i=0;i<n;i++)
{
int tx=0,ty=0;
char tt;
cin>>tx>>ty>>tt;
di[i].x=tx;
di[i].y=ty;
di[i].type=tt;
}//初始化完成
for(int i=0;i<m;i++)
{
int d1=0,d2=0,d3=0;
cin>>d1>>d2>>d3;
int flagAs=0,flagAb=0;
int flagBs=0,flagBb=0;
for(int j=0;j<n;j++)
{
int temp=d1+di[j].x*d2+di[j].y*d3;
char typ=di[j].type;
if(temp==0)
{
break;
}
else if(temp<0 && typ=='A')
{
flagAs=1;
}
else if(temp>0 && typ=='A')
{
flagAb=1;
}
else if(temp<0 && typ=='B')
{
flagBs=1;
}
else if(temp>0 && typ=='B')
{
flagBb=1;
}
}
if(flagAs==1 && flagAb==0 && flagBb==1 && flagBs==0)
{
cout<<"Yes"<<endl;
}
else if(flagAs==0 && flagAb==1 && flagBb==0 && flagBs==1)
{
cout<<"Yes"<<endl;
}
else
{
cout<<"No"<<endl;
}
}
system("pause");
return 0;
}