使用JAVA判斷凸多邊形的示例代碼
更新時間:2013年11月14日 11:56:56 作者:
本文提供了使用JAVA判斷凸多邊形的示例代碼供大家參考學(xué)習(xí),需要的朋友可以看一下
復(fù)制代碼 代碼如下:
以HDU2108為例,去AC吧。
//點逆序輸入
import java.util.Scanner;
//1s
public class HDU2108 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while(true) {
int x,y;
int n = sc.nextInt();
if(0==n) {
break;
}
Point[] p = new Point[n];
for(int i=0; i<n; i++) {
p[i] = new Point();
}
for(int i=0; i<n; i++) {
x = sc.nextInt();
y = sc.nextInt();
p[i] = new Point(x,y);
}
//凸多邊形
boolean tag = true;
int j,k,t;
for(int i=0; i<n; i++) {
//k,t直接對n求余就行了
j = i;
k = i+1;
t = i+2;
//以三角形為例看看
if(k==n) {
k = 0;
}
if(t==n+1) {
t = 1;
}
if(t==n) {
t = 0;
}
//注意是后面減去前面的
Point p1 = new Point(p[k].x - p[j].x,
p[k].y - p[j].y);
Point p2 = new Point(p[t].x - p[k].x,
p[t].y - p[k].y);
//叉積
int ans = p1.x*p2.y - p1.y*p2.x;
if(ans<0) {
tag = false;
break;
}
}
if(tag) {
System.out.println("convex");
}else {
System.out.println("concave");
}
}
}
}
class Point {
int x;
int y;
public Point() {
this.x = 0;
this.y = 0;
}
public Point(int x, int y) {
this.x = x;
this.y = y;
}
}
相關(guān)文章
Springboot 項目讀取Resources目錄下的文件(推薦)
這篇文章主要介紹了Springboot 項目讀取Resources目錄下的文件,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-11-11
SpringBoot3整合Nacos?V2.3.2的詳細過程
本文介紹了如何在?Spring?Boot?3.2.x?項目中整合?Nacos?2.3.2,包括依賴配置、Nacos?服務(wù)發(fā)現(xiàn)與動態(tài)配置的配置方法,通過整合?Nacos,Spring?Boot?應(yīng)用可以實現(xiàn)高效的服務(wù)發(fā)現(xiàn)、動態(tài)配置管理以及分布式系統(tǒng)中的靈活擴展,感興趣的朋友跟隨小編一起看看吧2024-11-11
java?String到底有多長?String超出長度該如何解決
在Java中,由于字符串常量池的存在,String常量長度限制取決于String常量在常量池中的存儲大小,下面這篇文章主要給大家介紹了關(guān)于java?String到底有多長?String超出長度該如何解決的相關(guān)資料,需要的朋友可以參考下2023-01-01

