国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

python Graham求凸包問題并畫圖操作

瀏覽:2日期:2022-06-17 15:17:53
python Graham求凸包并畫圖

python寫Graham沒有c++那么好寫,但是python畫圖簡單。只需要用matplotlib里的pyplot,c++畫圖太難了。

Graham算法寫起來比較簡單,只需要想辦法對最小點和其他的點所連成的直線,與x軸正半軸的夾角進行排序,然后其他的就直接套用Graham算法模板就好了,因為c++可以重載排序函數(shù)sort,不用計算角度(用其他的數(shù)學方法),但是python不行(也許是我不知道而已,菜)。

python必須要在結構體里面加上角度這個變量,然后才能按照角度排序。排好序后就變得容易了,用stack棧存放答案,算完答案后,用scatter(散點圖)畫出點,用plt(折線圖)畫邊界就好了。

import matplotlib.pyplot as pltimport mathimport numpy as np class Node: def __init__(self):self.x = 0self.y = 0self.angel = 0#和最左下的點連成的直線,與x軸正半軸的夾角大小 #按照角度從小到大排序def cmp(x): return x.angel def bottom_point(points): min_index = 0 n = len(points) #先判斷y坐標,找出y坐標最小的點,x坐標最小的點 for i in range(1, n):if points[i].y < points[min_index].y or (points[i].y == points[min_index].y and points[i].x < points[min_index].x): min_index = i return min_index #計算角度def calc_angel(vec): norm = math.sqrt(vec[0] * vec[0] + vec[1] * vec[1]) if norm == 0:return 0 angel = math.acos(vec[0]/norm) if vec[1] >= 0:return angel else:return math.pi * 2 - angel def multi(v1, v2): return v1[0] * v2[1] - v1[1] * v2[0] point = []n = 30#生成30個點的坐標,n可以修改for i in range(n): temp = Node() temp.x = np.random.randint(1, 100) temp.y = np.random.randint(1, 100) point.append(temp)index = bottom_point(point)for i in range(n): if i == index:continue #計算每個點和point[index]所連成的直線與x軸正半軸的夾角 vector = [point[i].x - point[index].x, point[i].y - point[index].y] #vector是向量 point[i].angel = calc_angel(vector)#排序point.sort(key=cmp)#答案存入棧中stack = []stack.append(point[0])stack.append(point[1])#for循環(huán)更新答案for i in range(2, n): L = len(stack) top = stack[L - 1] next_top = stack[L - 2] vec1 = [point[i].x - next_top.x, point[i].y - next_top.y] vec2 = [top.x - next_top.x, top.y - next_top.y] #一定要大于等于零,因為可能在一條直線上 while multi(vec1, vec2) >= 0:stack.pop()L = len(stack)top = stack[L - 1]next_top = stack[L - 2]vec1 = [point[i].x - next_top.x, point[i].y - next_top.y]vec2 = [top.x - next_top.x, top.y - next_top.y] stack.append(point[i])#畫出圖像for p in point: plt.scatter(p.x, p.y, marker=’o’, c=’g’)L = len(stack)for i in range(L-1): plt.plot([stack[i].x, stack[i+1].x], [stack[i].y, stack[i+1].y], c=’r’)plt.plot([stack[0].x, stack[L-1].x], [stack[0].y, stack[L-1].y], c=’r’)plt.show()Python 找到凸包 Convex hulls

圖形學可以說經(jīng)常遇到這東西了,這里給出一個庫函數(shù)的實現(xiàn)

from scipy.spatial import ConvexHullpoints = np.random.rand(10, 2) # 30 random points in 2-Dhull = ConvexHull(points)import matplotlib.pyplot as pltplt.plot(points[:,0], points[:,1], ’o’)for simplex in hull.simplices: plt.plot(points[simplex,0], points[simplex,1], ’k-’)plt.show()

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 91免费视| 在线播放亚洲视频 | 国产精品成人自拍 | 亚洲情a成黄在线观看动 | 东凛中文字幕 | 夜夜春夜夜夜夜猛噜噜噜噜噜 | 国产男女 爽爽爽爽视频 | 国内精品小视频在线 | 精品国产九九 | 国产成人资源 | 欧美经典成人在观看线视频 | 91四虎国自产在线播放线 | 成人精品视频在线观看播放 | 久久久综合久久 | 一级毛片一级毛片a毛片欧美 | 亚洲欧美在线免费观看 | 女人国产香蕉久久精品 | 久久香蕉国产线看免费 | 手机看片福利永久 | 日日摸日日碰夜夜97 | 亚洲在成人网在线看 | 亚洲精品456在线播放无广告 | 欧美精品一区二区在线观看播放 | 成人免费视频69 | 精品视频在线免费播放 | 久久亚洲视频 | 一区二区在线播放福利视频 | 免费国产高清精品一区在线 | 四川一级片 | 欧美三级在线观看视频 | 2017天天爽夜夜爽精品视频 | 国产欧美17694免费观看视频 | 黄网站色视频免费观看w | 国产精品99久久久久久www | 午夜看毛片 | 手机免费看毛片 | 9191精品国产费久久 | 日本香蕉一区二区三区 | 免费看a级毛片 | ccyycom草草影院成人91 | 美女张开腿让我桶 |