算法程序解决如下问题:质点在平面坐标系中运动,每次x或者y坐标增加或减少1,如何判断质点是否顺时针

1个回答

  • 不知道你怎么获取质点坐标,所以我在程序中固定了点坐标,方便test,你主要看calOrder方法中如何判断是否顺时针吧.代码如下:

    //质点类

    public class Spot {

    x05int x;

    x05int y;

    x05

    x05Spot(int x,int y){

    x05x05this.x = x;

    x05x05this.y = y;

    x05}

    }

    public class TestSpot {

    x05public static void main(String[] args){

    x05x05

    x05x05/*给定的三个点坐标,是有顺序的.

    x05x05 * 以(0,0),(0,1),(1,1),(1,0)(0,0)为例

    x05x05 * p1 表示 质点运动的第一个点坐标,即(0,0)这点

    x05x05 * p2 表示 质点运动的第二个点坐标,即(0,1)这点

    x05x05 * p3 表示 质点运动的第三个点坐标,即(1,1)这点

    x05x05 */

    x05x05Spot p1 = new Spot(0,0);

    x05x05Spot p2 = new Spot(0,1);

    x05x05Spot p3 = new Spot(1,1);

    x05x05

    x05x05

    x05x05TestSpot ts = new TestSpot();

    x05x05//调用函数,这三个参数也是有顺序的,同上

    x05x05System.out.print(ts.calOrder(p1,p2,p3));

    x05x05

    x05}

    x05

    x05public int calXY(Spot p1,Spot p2){

    x05x05

    x05x05/*

    x05x05 * 计算两个点之间x,y的位置变化

    x05x05 *

    x05x05 */

    x05x05int x = p1.x - p2.x;

    x05x05int y = p1.y - p2.y;

    x05x05

    x05x05if(x == 0){

    x05x05x05if(y < 0){

    x05x05x05x05return -1;

    x05x05x05}else

    x05x05x05x05return -2;

    x05x05}else if(x < 0){

    x05x05x05return 2;

    x05x05}else return 1;

    x05x05

    x05x05

    x05x05

    x05}

    x05

    x05public String calOrder(Spot p1,Spot p2,Spot p3){

    x05x05

    x05x05/*

    x05x05 * 计算是否顺时针

    x05x05 */

    x05x05

    x05x05

    x05x05//首先判断三个点间x,y的位置变化

    x05x05int num1 = this.calXY(p1,p2);

    x05x05int num2 = this.calXY(p2,p3);

    x05x05

    x05x05//然后根据所得判断

    x05x05if(num1 < 0){

    x05x05x05if((num1+num2) == 0){

    x05x05x05x05return "逆时针";

    x05x05x05}

    x05x05x05else return "顺时针";

    x05x05}

    x05x05

    x05x05if(num1 > 0){

    x05x05x05if((num1 + num2) == 0){

    x05x05x05x05return "顺时针";

    x05x05x05}

    x05x05x05else return "逆时针";

    x05x05}

    x05x05

    x05x05return null;

    x05}

    }