国产睡熟迷奷白丝护士系列精品,中文色字幕网站,免费h网站在线观看的,亚洲开心激情在线

      <sup id="hb9fh"></sup>
          1. 千鋒教育-做有情懷、有良心、有品質的職業(yè)教育機構

            手機站
            千鋒教育

            千鋒學習站 | 隨時隨地免費學

            千鋒教育

            掃一掃進入千鋒手機站

            領取全套視頻
            千鋒教育

            關注千鋒學習站小程序
            隨時隨地免費學習課程

            當前位置:首頁  >  技術干貨  > java的點在多邊形內的算法

            java的點在多邊形內的算法

            來源:千鋒教育
            發(fā)布人:yyy
            時間: 2023-06-28 14:34:00 1687934040

              Java的點在多邊形內的算法通常采用射線法(也稱射線交叉算法)來實現(xiàn)。該算法基于以下原理:如果一個點在多邊形內部,則從該點畫一條水平向右的射線,與多邊形相交的次數(shù)為奇數(shù);如果在多邊形外部,則相交次數(shù)為偶數(shù);如果在多邊形邊界上,則相交次數(shù)不確定,有時為偶數(shù),有時為奇數(shù)。

              具體實現(xiàn)步驟如下:

              定義一個射線,該射線與待判斷點的y軸相交,并向右延伸到無窮遠。

              遍歷多邊形的所有邊,計算該邊與射線的交點。

              如果交點在射線的右側,則不計數(shù);如果在射線的左側,則計數(shù)。

              如果交點在射線上,則將相交次數(shù)+1,但不計入結果。

              如果相交次數(shù)為奇數(shù),則點在多邊形內部,否則在多邊形外部。

              以下是Java實現(xiàn)的示例代碼:

            public static boolean isPointInPolygon(Point2D.Double point, List<Point2D.Double> polygon) {
            int count = 0;
            int size = polygon.size();
            for (int i = 0; i < size; i++) {
            Point2D.Double p1 = polygon.get(i);
            Point2D.Double p2 = polygon.get((i + 1) % size);
            if (p1.y == p2.y) {
            continue;
            }
            if (point.y < Math.min(p1.y, p2.y)) {
            continue;
            }
            if (point.y >= Math.max(p1.y, p2.y)) {
            continue;
            }
            double x = (point.y - p1.y) * (p2.x - p1.x) / (p2.y - p1.y) + p1.x;
            if (x > point.x) {
            count++;
            } else if (x == point.x) {
            return true;
            }
            }
            return count % 2 == 1;
            }

               該方法接受一個待判斷點和一個多邊形的點集合,返回該點是否在多邊形內部的布爾值。其中Point2D.Double表示二維平面上的點,x和y分別表示橫縱坐標。

            tags: java算法
            聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
            10年以上業(yè)內強師集結,手把手帶你蛻變精英
            請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
            免費領取
            今日已有369人領取成功
            劉同學 138****2860 剛剛成功領取
            王同學 131****2015 剛剛成功領取
            張同學 133****4652 剛剛成功領取
            李同學 135****8607 剛剛成功領取
            楊同學 132****5667 剛剛成功領取
            岳同學 134****6652 剛剛成功領取
            梁同學 157****2950 剛剛成功領取
            劉同學 189****1015 剛剛成功領取
            張同學 155****4678 剛剛成功領取
            鄒同學 139****2907 剛剛成功領取
            董同學 138****2867 剛剛成功領取
            周同學 136****3602 剛剛成功領取
            相關推薦HOT