http://poj.org/problem?id=1265
//* @author: ccQ.SuperSupper
import java.io.*;
import java.util.*;
class Point{
int x,y;
}
public class Main {
static final int N = 100+10;
static int n;
static Point Area[] = new Point[N];
static void start(){
for(int i=0;i< N;++i)
Area[i] = new Point();
}
public static void main(String []args) throws Exception{
int t,cs=1,i,x,y;
StreamTokenizer cin = new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));
start();
t = Get_Num(cin);
while(t--!=0){
n = Get_Num(cin);
Area[0].x = Area[0].y = 0;
for(i=1;i<=n;++i){
Area[i].x = Get_Num(cin)+Area[i-1].x;
Area[i].y = Get_Num(cin)+Area[i-1].y;
}
solve(cs++);
}
}
static int Get_Num(StreamTokenizer cin) throws Exception{
cin.nextToken();
return (int) cin.nval;
}
static int GCD(int a,int b){
if(b==0) return a;
return GCD(b,a%b);
}
static int node_in_line(Point a,Point b){
int x,y;
x = abs(a.x-b.x);
y = abs(a.y-b.y);
return GCD(x,y);
}
static int abs(int a){
if(a>=0) return a;
return -a;
}
static int get_area(Point a,Point b,Point c){
return (c.x-a.x)*(b.y-a.y) - (b.x-a.x)*(c.y-a.y);
}
static void solve(int cs){
int I,E=0,area=0,i;
for(i=0;i< n;++i){
E+=node_in_line(Area[i],Area[(i+1)%n]);
}
for(i=2;i< n;++i){
area += get_area(Area[0],Area[i-1],Area[i]);
}
area = abs(area);
I = (area-E+2)/2;
System.out.print("Scenario #"+cs+":n"+I+" "+E+" ");
if(area%2==0) System.out.println(area/2+".0n");
else System.out.println(area/2+".5n");
}
}
Meta
-
Recent Posts
Recent Comments
Archives
- May 2024
- April 2023
- February 2023
- January 2023
- December 2022
- November 2022
- September 2022
- June 2022
- July 2021
- January 2021
- February 2020
- September 2019
- March 2018
- February 2018
- August 2016
- July 2016
- June 2016
- May 2016
- April 2016
- March 2016
- February 2016
- January 2016
- December 2015
- November 2015
- October 2015
- September 2015
- August 2015
- July 2015
- June 2015
- May 2015
- April 2015
- March 2015
- February 2015
- January 2015
- December 2014
- November 2014
- October 2014
- September 2014
- August 2014
- July 2014
- June 2014
- May 2014
- April 2014
- March 2014
- February 2014
- January 2014
- December 2013
- November 2013
- October 2013
- September 2013
- August 2013
- July 2013
- June 2013
- May 2013
- April 2013
- March 2013
- February 2013
- January 2013
- December 2012
- November 2012
- October 2012
- September 2012
- August 2012
- July 2012
- June 2012
- May 2012
- April 2012
- March 2012
- February 2012
- January 2012
- December 2011
- November 2011
- October 2011
- September 2011
- August 2011
- July 2011
- June 2011
- May 2011
- April 2011
- March 2011
- February 2011
- January 2011
- December 2010
- November 2010
- October 2010
- September 2010
- August 2010
- July 2010
- June 2010
- May 2010
- April 2010
- March 2010
- February 2010
- January 2010
- December 2009
- November 2009
- October 2009
- September 2009
- August 2009
- July 2009
- June 2009
- May 2009
- April 2009
- March 2009
- February 2009
Categories
