基于GBDT+Tkinter+穷举法按排队时间预测最优路径的智能导航推荐系统——机器学习算法应用(含Python工程源码)+数据集(三)

目录

  • 前言
  • 总体设计
    • 系统整体结构图
    • 系统流程图
  • 运行环境
    • Python环境
    • Pycharm 环境
    • Scikit-learnt
  • 模块实现
    • 1. 数据预处理
    • 2. 客流预测
    • 3. 百度地图API调用
    • 4. GUI界面设计
      • 1)手绘地图导入
      • 2)下拉菜单设计
      • 3)复选框设计
      • 4)最短路径结果输出界面设计
      • 5)智能推荐结果输出设计
      • 6)界面展示
    • 5. 路径规划
    • 6. 智能推荐
  • 相关其它博客
  • 工程源代码下载
  • 其它资料下载


在这里插入图片描述

前言

本项目的核心是利用百度地图API获取步行时间和借助GBDT(梯度提升决策树)模型进行排队时间的预测。它旨在为用户提供一种自主选择多个目的地的功能,然后系统会输出最佳路线规划的结果,并根据用户的选择提供智能化的建议。

首先,项目利用百度地图API,能够获取到步行时间信息。这些信息包括从一个地点到另一个地点所需的预计步行时间。这个步骤确保了系统具有地理位置感知能力,可以理解用户的出行需求。

接下来,项目使用GBDT模型,这是一种强大的机器学习模型,用于预测排队时间。GBDT模型会考虑多个因素,如交通状况、目的地之间的距离、历史排队数据等,来预测用户在不同地点排队的时间。

一旦获取了这些信息,系统可以让用户自主选择多个目的地。用户可以输入他们的出发点和多个目标地点,然后系统会根据百度地图API的步行时间和GBDT模型的排队时间预测,计算出最佳路线规划。这个规划考虑了用户的时间限制、排队时间、步行时间等因素,以确保用户能够在最短的时间内到达所有目的地。

最后,系统还可以根据用户的选择,提供智能化的建议。例如,如果用户希望优先选择最短排队时间的目的地,系统可以相应地调整路线规划。

总的来说,这个项目结合了地图数据和机器学习技术,为用户提供了一个方便的自主选择多个目的地并获取最佳路线规划的工具。这对于城市出行和旅游规划非常有用,可以帮助用户更高效地安排行程。

总体设计

本部分包括系统整体结构图和系统流程图。

系统整体结构图

系统整体结构如图所示。

在这里插入图片描述

系统流程图

系统流程如图所示。

在这里插入图片描述
路径规划流程如图所示。
在这里插入图片描述

计算路径耗时流程,如图所示。

在这里插入图片描述

运行环境

本部分包括 Python 环境、Pycharm 环境和Scikit-learn环境。

Python环境

需要Python 3.6及以上配置,在Windows环境下推荐下载Anaconda完成Python所需环境的配置,下载地址为https://www.anaconda.com/,也可下载虚拟机在Linux环境下运行代码。

Pycharm 环境

PyCharm下载地址为http://www.jetbrains.com/pycharm/download/#section=windows,进入网站后单击Comminity版本下的DOWNLOAD下载安装包,下载完成后安装。单击Create New Project创建新的项目文件,Location为存放工程的路径,单击project附近的三角符号,可以看到PyCharm已经自动获取Python 3.6,单击create完成。

Scikit-learnt

安装CPU版本的Scikit-learn: pip install -U --ignore-installed scikit-learn, 或者从Anaconda环境中直接搜索 scikit-learn包进行下载、安装。

模块实现

本项目包括6个模块:数据预处理、客流预测、百度地图API调用、GUI界面设计、路径规划和智能推荐,下面分别给出各模块的功能介绍及相关代码。

1. 数据预处理

详见博客:https://blog.csdn.net/qq_31136513/article/details/133011765#1__49

2. 客流预测

详见博客:https://blog.csdn.net/qq_31136513/article/details/133011802#2__54

3. 百度地图API调用

详见博客:https://blog.csdn.net/qq_31136513/article/details/133011802#3_API_134

4. GUI界面设计

导入Tkinter包进行GUI设计。用户通过下拉菜单手动选择当前位置,勾选目的地。单击“确认”按钮后调用create()函数跳转至最佳路线输出界面。

1)手绘地图导入

相关代码如下:

#背景初始化部分
window = tkinter.Tk()
window.geometry('900x500')
window.title('智能导航系统——欢乐谷')
#显示图片
#通过PIL打开图片
img = Image.open('C:/Users/99509/Desktop/map.jpg')  
img = img.resize((750,500),Image.ANTIALIAS) #Image.ANTIALIAS使图片不模糊
#通过PIL生成PhotoImage对象,即可正常加载
photo = ImageTk.PhotoImage(img)
imageLabel = Label(window, image=photo)
imageLabel.pack(side=LEFT)

2)下拉菜单设计

相关代码如下:

ss=Label(window,text="您当前位置为",justify=RIGHT)
ss.pack()
comvalue=tkinter.StringVar() #窗体自带的文本,新建一个值  
comboxlist=ttk.Combobox(window,textvariable=comvalue) #初始化  
comboxlist["values"]=("入口","玛雅天灾","雪域金翅","异域魔窟","奥德赛之旅","太阳神车","天地双雄","能量风暴")  
all_paths_first=""
def xFunc(event):global all_paths_first#print(comboxlist.get())#当前位置if comboxlist.get()=="入口":all_paths_first=0elif comboxlist.get()=="玛雅天灾":all_paths_first=1elif comboxlist.get()=="雪域金翅":all_paths_first=2elif comboxlist.get()=="异域魔窟":all_paths_first=3elif comboxlist.get()=="奥德赛之旅":all_paths_first=4elif comboxlist.get()=="太阳神车":all_paths_first=5elif comboxlist.get()=="天地双雄":all_paths_first=6elif comboxlist.get()=="能量风暴":all_paths_first=7
comboxlist.bind("<<ComboboxSelected>>",xFunc)  
#绑定事件,(下拉列表框被选中时,绑定xFunc()函数)  
comboxlist.pack()  

3)复选框设计

复选框格式是一致的,为了界面简洁,只展示一个复选框设计。

#count判断是否需要调用百度地图API,奇数表示选中
count1=0
N = []
def myEvent1():global count1if count1%2==0:count1+=1else:count1+=1
#项目选择部分
v1=IntVar()
c1=Checkbutton(window,text='入口',variable=v1,justify=RIGHT,command=myEvent1) #存放选中状态
c1.pack()
l1=Label(window,textvariable=v1,justify=RIGHT)
l1.pack() #未选中显示为0,选中显示为1

4)最短路径结果输出界面设计

相关代码如下:

total=[]    #存放被选择的目的地
total_n=[]  #存放未被选择的地点
#选择地点完成后调出最短路径结果输出界面
def create():window2 = tkinter.Toplevel() #新建子窗口windows2window2.geometry('300x200')window2.title('计算页面')s0=Label(window2,text="您选择了:") #文字框s0s0.pack()    #选择目的地if count1%2==1:          #如果被选中N.append(0)           #N列表中增加0total.append("入口") #total列表中增加“入口”else:                       #如果未被选中N_notchoose.append(0) #N_notchoose列表中增加0total_n.append("入口") #total_n列表中增加“入口”if count2%2==1: #以下同理N.append(1)total.append("玛雅天灾")else:N_notchoose.append(1)total_n.append("玛雅天灾")if count3%2==1:N.append(2)total.append("雪域金翅")else:N_notchoose.append(2)total_n.append("雪域金翅")if count4%2==1:N.append(3)total.append("异域魔窟")else:N_notchoose.append(3)total_n.append("异域魔窟")if count5%2==1:N.append(4)total.append("奥德赛之旅")else:N_notchoose.append(4)total_n.append("奥德赛之旅")if count6%2==1:N.append(5)total.append("太阳神车")else:N_notchoose.append(5)total_n.append("太阳神车")if count7%2==1:N.append(6)total.append("天地双雄")else:N_notchoose.append(6)total_n.append("天地双雄")if count8%2==1:N.append(7)total.append("能量风暴")else:N_notchoose.append(7)total_n.append("能量风暴")s_total=Label(window2,text=total) #输出用户选中的地点s_total.pack()s9=Label(window2,text="最佳路线为:") #文字框s9s9.pack()get_time(N) #调用get_time进行运算PLAN=[]     #用于存放计划路径#输出路径for i in range(0,len(N)+1):if PATH[i]==0:PLAN.append("入口")elif PATH[i]==1:PLAN.append("玛雅天灾")elif PATH[i]==2:PLAN.append("雪域金翅")elif PATH[i]==3:PLAN.append("异域魔窟")elif PATH[i]==4:PLAN.append("奥德赛之旅")elif PATH[i]==5:PLAN.append("太阳神车")elif PATH[i]==6:PLAN.append("天地双雄")else:PLAN.append("能量风暴")s10=Label(window2,text=PLAN) #输出计划的最短路径s10.pack()s11=Label(window2,text="\n大约耗时:"+str(round(TIME[0],2))+"小时") 
#输出对应总耗时s11.pack()b2=Button(window2,text='猜你喜欢',command=create_guess) 
#新建“猜你喜欢”按钮进入智能推荐模块b2.pack()b3=Button(window2,text='退出',command=window.destroy)  #退出按钮b3.pack() 

5)智能推荐结果输出设计

相关代码如下:

#创建智能推荐的页面
def create_guess():window3 = tkinter.Toplevel() #新建子窗口windows3window3.geometry('400x250')window3.title('猜你喜欢')s0=Label(window3,text="您选择了:") #文字框s0s0.pack()s_total=Label(window3,text=total) #输出用户选中的地点s_total.pack()s7=Label(window3,text="为您推荐:") #文字框s7s7.pack()try:guess_time(N) #调用guess_time函数,计算推荐地点及推荐最短路径except:tkinter.messagebox.showwarning("提示", "选取地点有误!\n请退出重新选取")
#加入异常处理,跳出提示框PLAN=[] #存放推荐最短路径#输出路径for i in range(0,len(N)+2):if PATH_guess[i]==0:PLAN.append("入口")elif PATH_guess[i]==1:PLAN.append("玛雅天灾")elif PATH_guess[i]==2:PLAN.append("雪域金翅")elif PATH_guess[i]==3:PLAN.append("异域魔窟")elif PATH_guess[i]==4:PLAN.append("奥德赛之旅")elif PATH_guess[i]==5:PLAN.append("太阳神车")elif PATH_guess[i]==6:PLAN.append("天地双雄")else:PLAN.append("能量风暴")s8=Label(window3,text=location[recommend]) #输出推荐的地点s8.pack()s9=Label(window3,text="加入推荐地点的最佳路线为:") #文本框s9s9.pack()s10=Label(window3,text=PLAN) #输出推荐的最短路径s10.pack()s11=Label(window3,text="\n大约耗时:"+str(round(TIME_guess[0],2))+"小时") #输出推荐的总耗时s11.pack()s12=Label(window3,text="预计比原路线多花费:"+str(round((TIME_guess[0]-TIME[0]),2))+"小时") #输出推荐一个地点后的总耗时与之前总耗时的差s12.pack()b3=Button(window3,text='返回',command=window3.destroy) 
#“返回”按钮,返回上一界面b3.pack()b4=Button(window3,text='退出',command=window.destroy) 
#“退出”按钮,退出程序b4.pack()

6)界面展示

GUI主页面如图所示。
在这里插入图片描述

下拉菜单如图所示。
在这里插入图片描述

5. 路径规划

通过调用百度地图API模块产生节点之间的步行时间矩阵和客流模型,应用穷举法设计算法,得出最佳路线规划。

GUI界面下拉菜单中选择当前位置作为所有可能线路的起点,复选框中目的地作为节点,调用itertools库中的permutations()函数进行全排列,路线每到节点时间、排队时间输出在cmd窗口,如图所示。

在这里插入图片描述

最佳路线和总耗时输出在GUI模块设计的界面当中,如图所示。

在这里插入图片描述
相关代码如下:

#获得最佳路径和出游时间
def get_time(N):global TIMEglobal PATHgbdt_6_model_path = "D:/~STUDY~/Grade3/信息系统设计/final_files/data/模型/gbdt_6.model" gbdt_model = joblib.load(gbdt_6_model_path) #加载模型#初始化客流模型顺序不可改变features=pd.DataFrame({'temperature_average':[2],'wind_average':[0],'weather_average':[6],'time':[0],'isholiday':[0],'dayofweek':[1]})#N = [0,1,2,3] #GUI界面单击选择n=len(N)+1print(all_paths_first)all_paths_tuple=list(itertools.permutations(N,n-1)) 
#得到的全排列是元组tupleall_paths=[]#tuple类型不能插入操作,所以转换成listfor i in range(0,math.factorial(n-1)):all_paths.append(list(all_paths_tuple[i]))all_paths[i].insert(0,all_paths_first)path = list()all_time = float('inf') #无穷大#第i条路线for i in range(0,math.factorial(n-1)):time = 0 #(h)nowtime = 9 #可以获取当前时间,需要事件表示的转换(h)print("第"+str(i+1)+"条路线为:"+str(all_paths[i]))#第i条路线的第j个地点for j in range(0,n-1):time = time + (walk_time[all_paths[i][j]][all_paths[i][j+1]]/3600) 
#到达一个地点的时间nowtime = nowtime+time features['time'] = nowtimegbdt_predict_labels = gbdt_model.predict(features)/2000 
#客流量/2000当作时间(h)print("现在的时间是:"+str(nowtime)+" 此时"+str(j)+"点的排队时间为:"+str(gbdt_predict_labels)+"h")time = time + gbdt_predict_labels + (PLAYTIME[j]/60)print("耗时为:"+str(time))
print("===================================================================")if all_time>time:all_time = timepath = all_paths[i]print("耗时最短的路径为:"+str(path)+" 耗时为:"+str(all_time))PATH = pathTIME = all_time

6. 智能推荐

系统将用户未选择的地点一次分别加入已选择的队列中进行运算,其基本思路与最佳路线规划模块一致,采用穷举法得到所有路线及其总耗时,最后将它们输出,实现智能推荐。

相关代码如下:

#智能推荐“猜你喜欢”的运算
def guess_time(N):global TIME_guessglobal PATH_guessglobal recommendpath_whole = list()all_time_whole = float('inf') #无穷大gbdt_6_model_path = "D:/~STUDY~/Grade3/信息系统设计/final_files/data/模型/gbdt_6.model" gbdt_model = joblib.load(gbdt_6_model_path) #加载模型features=pd.DataFrame({'temperature_average':[2],'wind_average':[0],'weather_average':[6],'time':[0],'isholiday':[0],'dayofweek':[1]})#N = [0,1,2,3] #GUI界面单击选择print('起点是:'+str(all_paths_first))for nn in range(0,len(N_notchoose)): 
#把未选择的地点分别加入到已选择的队列中进行计算guess_path = []guess_path = N[:]guess_path.append(N_notchoose[nn]) #构建推荐的列表print(guess_path)if(all_paths_first in guess_path):pass    #如果未选择的地点是起点,则跳过else:all_paths_tuple=list(itertools.permutations(guess_path,len(guess_path))) 
#得到的全排列是元组tupleall_paths=[]#tuple类型不能插入操作,所以转换成list#for i in range(0,math.factorial(n-1)):调试代码for i in range(0,math.factorial(len(guess_path))):all_paths.append(list(all_paths_tuple[i]))all_paths[i].insert(0,all_paths_first)path = list()all_time = float('inf') #无穷大#第i条路线for i in range(0,math.factorial(len(guess_path))):time = 0 #(h)nowtime = 9 #可以获取当前时间,需要事件表示的转换(h)print("第"+str(i+1)+"条路线为:"+str(all_paths[i]))#第i条路线的第j个地点for j in range(0,len(guess_path)):time = time + (walk_time[all_paths[i][j]][all_paths[i][j+1]]/3600) 
#到达一个地点的时间nowtime = nowtime+time features['time'] = nowtimegbdt_predict_labels = gbdt_model.predict(features)/2000 
#客流量/2000当作时间(h)print("现在的时间是:"+str(nowtime)+" 此时"+str(j)+"点的排队时间为:"+str(gbdt_predict_labels)+"h")time = time + gbdt_predict_labels + (PLAYTIME[j]/60)print("耗时为:"+str(time))print("")if all_time>time:all_time = timepath = all_paths[i]if all_time_whole>all_time:all_time_whole = all_timepath_whole=path[:]recommend = N_notchoose[nn]print("推荐第"+str(recommend)+"个景点")print("推荐第"+str(recommend)+"个景点")print("智能推荐耗时最短的路径为a:"+str(path_whole)+"  耗时为:"+str(all_time_whole))PATH_guess = path_wholeTIME_guess = all_time_whole

在cmd窗口输出所有路径及该路径每到一节点的时间,如图所示。

在这里插入图片描述

在GUI模块设计的界面中显示最佳路线和总耗时,如图所示。

在这里插入图片描述

相关其它博客

基于GBDT+Tkinter+穷举法按排队时间预测最优路径的智能导航推荐系统——机器学习算法应用(含Python工程源码)+数据集(一)

基于GBDT+Tkinter+穷举法按排队时间预测最优路径的智能导航推荐系统——机器学习算法应用(含Python工程源码)+数据集(二)

基于GBDT+Tkinter+穷举法按排队时间预测最优路径的智能导航推荐系统——机器学习算法应用(含Python工程源码)+数据集(四)

工程源代码下载

详见本人博客资源下载页


其它资料下载

如果大家想继续了解人工智能相关学习路线和知识体系,欢迎大家翻阅我的另外一篇博客《重磅 | 完备的人工智能AI 学习——基础知识学习路线,所有资料免关注免套路直接网盘下载》
这篇博客参考了Github知名开源平台,AI技术平台以及相关领域专家:Datawhale,ApacheCN,AI有道和黄海广博士等约有近100G相关资料,希望能帮助到所有小伙伴们。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/137839.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql限制用户登录失败次数,限制时间

mysql用户登录限制设置 mysql 需要进行用户登录次数限制,当使用密码登录超过 3 次认证链接失败之后,登录锁住一段时间,禁止登录这里使用的 mysql: 8.1.0 这种方式不用重启数据库. 配置: 首先进入到 mysql 命令行:然后需要安装两个插件: 在 mysql 命令行中执行: mysql> INS…

数据分析与可视化项目技术参考

&#x1f64c;秋名山码民的主页 &#x1f602;oi退役选手&#xff0c;Java、大数据、单片机、IoT均有所涉猎&#xff0c;热爱技术&#xff0c;技术无罪 &#x1f389;欢迎关注&#x1f50e;点赞&#x1f44d;收藏⭐️留言&#x1f4dd; 获取源码&#xff0c;添加WX 目录 1. 考核…

科目二倒车入库

调整座位和后视镜 离合踩到底大腿小腿成130-140 上半身90-100 座椅高度能看到前方全部情况 后视镜调节到能看到后门把手&#xff0c;且后门把手刚好在后视镜上方边缘、离车1/3处。 保持直线&#xff1a; 前进&#xff1a; 车仪表盘中央的原点和地面上的黄线擦边&#xff…

zookeeper可视化工具ZooInspector用法

最近在做银行的项目&#xff0c;用到了thrift&#xff0c;rpc和zookeeper&#xff0c;所有应用都是注册到zookeeper上的&#xff0c;想知道哪些应用注册上了&#xff0c;就用到ZooInspector这个可视化的工具。 1&#xff0c;下载 链接&#xff1a;https://issues.apache.org/…

关于数据权限的设计

在项目实际开发中我们不光要控制一个用户能访问哪些资源&#xff0c;还需要控制用户只能访问资源中的某部分数据。 控制一个用户能访问哪些资源我们有很成熟的权限管理模型即RBAC&#xff0c;但是控制用户只能访问某部分资源&#xff08;即我们常说的数据权限&#xff09;使用R…

ABB COM0011 2RAA005844A0007J编码器模块

ABB COM0011 2RAA005844A0007J 编码器模块是用于测量和反馈旋转或线性位置信息的设备&#xff0c;通常用于自动化、机器控制和运动控制系统。以下是该编码器模块可能具备的产品功能&#xff1a; 位置测量&#xff1a;ABB COM0011 2RAA005844A0007J 编码器模块的主要功能是测量旋…

【Java 基础篇】Java 线程通信详解

多线程编程在实际应用中非常常见&#xff0c;但随之而来的问题是线程之间的通信。线程通信是多线程编程中一个至关重要的概念&#xff0c;它涉及到线程之间的信息传递、同步和协作。本篇博客将详细解释Java中的线程通信&#xff0c;包括什么是线程通信、为什么需要线程通信、如…

油猴Safari浏览器辅助插件:Tampermonkey for Mac中文版

油猴脚本Tampermonkey是一款油猴Safari浏览器辅助插件&#xff0c;是一款适用于Safari用户的脚本管理&#xff0c;能够方便管理不同的脚本。虽然有些受支持的浏览器拥有原生的用户脚本支持&#xff0c;但tampermonkey油猴插件将在您的用户脚本管理方面提供更多的便利&#xff0…

uni-app 新增 微信小程序之新版隐私协议

一、manifest.json中配置 "__usePrivacyCheck__": true 二、编写封装后的组件 <template><view class"privacy" v-if"showPrivacy"><view class"content"><view class"title">隐私保护指引</…

蓝桥杯每日一题2023.9.21

蓝桥杯2021年第十二届省赛真题-异或数列 - C语言网 (dotcpp.com) 题目描述 Alice 和 Bob 正在玩一个异或数列的游戏。初始时&#xff0c;Alice 和 Bob 分别有一个整数 a 和 b&#xff0c;有一个给定的长度为 n 的公共数列 X1, X2, , Xn。 Alice 和 Bob 轮流操作&#xff0…

恢复数据库 NBU ZDLRA Backup

Duplicate of specific PDB in LOCAL UNDO for specific tablespaces using Tape/ZDLRA Backup (Doc ID 2926039.1)​编辑To Bottom In this Document Goal Solution References APPLIES TO: Oracle Database - Enterprise Edition - Version 12.2.0.1 and later Information…

如何解决 503 Service Temporarily Unavailable?

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f405;&#x1f43e;猫头虎建议程序员必备技术栈一览表&#x1f4d6;&#xff1a; &#x1f6e0;️ 全栈技术 Full Stack: &#x1f4da…

轻松使用androidstudio交叉编译libredwg库

对于安卓或嵌入式开发者而言,交叉编译是再熟悉不过的操作了,可是对于一些刚入门或初级开发者经常会遇到这样的问题:如何交叉编译C++库来生成安卓下的so库呢? 最近有一些粉丝找到我求救,那么我最近刚好有空大致研究了下,帮他们成功编译了其中一个libredwg的C++库,这篇文章…

21天学会C++:Day13----动态内存管理

CSDN的uu们&#xff0c;大家好。这里是C入门的第十三讲。 座右铭&#xff1a;前路坎坷&#xff0c;披荆斩棘&#xff0c;扶摇直上。 博客主页&#xff1a; 姬如祎 收录专栏&#xff1a;C专题 目录 1. 加深对内存四区的理解 2. new-delete 与 malloc-free 2.1 能否用 fre…

滚雪球学Java(31):玩转多维数组:高效访问和遍历

&#x1f3c6;本文收录于「滚雪球学Java」专栏&#xff0c;专业攻坚指数级提升&#xff0c;助你一臂之力&#xff0c;带你早日登顶&#x1f680;&#xff0c;欢迎大家关注&&收藏&#xff01;持续更新中&#xff0c;up&#xff01;up&#xff01;up&#xff01;&#xf…

离散数学 学习 之一阶逻辑的前束范式

敲重点 如果是蕴含式的前件要改变符号&#xff0c;后件不需要

uniapp选择地址弹窗组件

1.效果 2.子组件在components里面创建组件AddreessWindow <template><view style"position: relative;z-index: 999999 !important;"><view class"address-window" :class"value true ? on : "><view class"title…

【LeetCode每日一题合集】2023.9.11-2023.9.17(⭐反悔贪心拓扑排序Floyd)

文章目录 630. 课程表 III解法——反悔贪心⭐⭐⭐⭐⭐ 1462. 课程表 IV⭐解法1——拓扑排序预处理解法2——Floyd算法判断是否存在路径 2596. 检查骑士巡视方案&#xff08;方向模拟&#xff09;1222. 可以攻击国王的皇后&#xff08;方向模拟&#xff09;LCP 50. 宝石补给&…

Leetcode 106. 从中序与后序遍历序列构造二叉树

文章目录 题目代码&#xff08;9.18 首刷自解&#xff09; 题目 Leetcode 106. 从中序与后序遍历序列构造二叉树 代码&#xff08;9.18 首刷自解&#xff09; class Solution { public:unordered_map<int, int> val2Index;TreeNode* buildTree(vector<int>& …

C++运算符优先级一览表

VC常用功能开发汇总&#xff08;专栏文章列表&#xff0c;欢迎订阅&#xff0c;持续更新...&#xff09;https://blog.csdn.net/chenlycly/article/details/124272585C软件异常排查从入门到精通系列教程&#xff08;专栏文章列表&#xff0c;欢迎订阅&#xff0c;持续更新...&a…