500MS弄到79MS,求多边形面积,有可能是凹,用叉积就可以了,不能存所有点,会MLE
一次读入比单个读入快
#include<iostream>
#include<math.h>
using namespace std;
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
struct point
{__int64 x,y;};
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
__int64 dx[]=
{0,-1,0,1,-1,0,1,-1,0,1};
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
__int64 dy[]=
{0,-1,-1,-1,0,0,0,1,1,1};
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
//__int64 xmult(point p0,point p1,point p2){
// return (p1.x-p0.x)*(p2.y-p0.y)-(p2.x-p0.x)*(p1.y-p0.y);
//}
char path[1000010];
int main()
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
int t;
point p0,p1,p2;
__int64 ans;
scanf("%d",&t);
while(t--)
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
p0.x=0;
p0.y=0;
p2=p1=p0;
ans=0;
scanf(" %s",path);
int i=0;
for(i=0;path[i]!='5';i++)
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
p1=p2;
p2.x+=dx[path[i]-'0'];
p2.y+=dy[path[i]-'0'];
ans+=(p1.x-p0.x)*(p2.y-p0.y)-(p2.x-p0.x)*(p1.y-p0.y);
}
if(ans<0) ans*=-1;
printf("%I64d",(ans>>1));
if(((ans>>1)<<1)==ans) printf("\n");
else printf(".5\n");
}
return 0;
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
posted on 2009-10-06 13:12
wyiu 阅读(135)
评论(0) 编辑 收藏 引用 所属分类:
POJ