郭其先生利用DeepSeek实现的PostgreSQL递归CTE实现DFS写法

测试用表

CREATETABLEtree_nodes(idINTPRIMARYKEY,parent_idINTREFERENCEStree_nodes(id),nameVARCHAR(50));INSERTINTOtree_nodesVALUES(1,NULL,'根节点'),(2,1,'子节点1'),(3,1,'子节点2'),(4,2,'孙子节点1'),(5,2,'孙子节点2'),(6,3,'孙子节点3');

使用递归 CTE 实现 DFS:

WITHRECURSIVE dfsAS(-- 锚点:从根节点开始SELECTid,parent_id,name,1ASdepth,ARRAY[id]ASpath,ARRAY[name]::text[]ASpath_names,FALSEASis_cycleFROMtree_nodesWHEREparent_idISNULLUNIONALL-- 递归部分:深度优先遍历SELECTtn.id,tn.parent_id,tn.name,d.depth+1,d.path||tn.id,d.path_names||tn.name,tn.id=ANY(d.path)ASis_cycleFROMtree_nodes tnJOINdfs dONtn.parent_id=d.idWHERENOTd.is_cycle-- 防止循环)-- 按深度优先顺序输出SELECTid,parent_id,name,depth,path,path_namesFROMdfsORDERBYpath;

使用栈模拟 DFS

WITHRECURSIVE dfs_stackAS(-- 初始栈:包含根节点SELECT1ASstep,idAScurrent_node,name,ARRAY[id]ASstack,ARRAY[]::INT[]ASvisited,'visit'ASactionFROMtree_nodesWHEREparent_idISNULLUNIONALL-- 模拟栈操作:弹出、压入SELECTd.step+1,CASE-- 如果有未访问的子节点,访问第一个WHENEXISTS(SELECT1FROMtree_nodes tnWHEREtn.parent_id=d.current_nodeANDtn.id!=ALL(d.visited))THEN(SELECTtn.idFROMtree_nodes tnWHEREtn.parent_id=d.current_nodeANDtn.id!=ALL(d.visited)ORDERBYtn.idLIMIT1)-- 否则回溯ELSEd.stack[array_length(d.stack,1)-1]END,tn.name,CASE-- 访问新节点:压栈WHENEXISTS(SELECT1FROMtree_nodes tnWHEREtn.parent_id=d.current_nodeANDtn.id!=ALL(d.visited))THENd.stack||(SELECTtn.idFROMtree_nodes tnWHEREtn.parent_id=d.current_nodeANDtn.id!=ALL(d.visited)ORDERBYtn.idLIMIT1)-- 回溯:出栈ELSEd.stack[1:array_length(d.stack,1)-1]END,d.visited||d.current_node,CASEWHENEXISTS(SELECT1FROMtree_nodes tnWHEREtn.parent_id=d.current_nodeANDtn.id!=ALL(d.visited))THEN'push'ELSE'pop'ENDFROMdfs_stack dLEFTJOINtree_nodes tnONtn.id=d.current_nodeWHEREarray_length(d.stack,1)>0-- 栈不为空时继续)SELECTstep,current_node,name,stack,action,visitedFROMdfs_stackORDERBYstep;

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

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

相关文章

PDF-Extract-Kit质量控制:确保提取结果准确

PDF-Extract-Kit质量控制:确保提取结果准确 1. 引言 1.1 技术背景与行业痛点 在科研、教育和出版领域,PDF文档承载了大量结构化信息,包括文本、表格、图像和数学公式。然而,传统PDF解析工具往往难以准确识别复杂版式内容&#…

Keil4调试寄存器视图:图解说明使用技巧

看懂机器的语言:Keil4寄存器视图实战全解你有没有遇到过这样的场景?代码逻辑明明写得清清楚楚,串口初始化也一步步来,可就是发不出一个字节;或者程序突然卡死在HardFault_Handler里,打印日志还没来得及输出…

HY-MT1.5实时翻译系统搭建:边缘计算最佳配置

HY-MT1.5实时翻译系统搭建:边缘计算最佳配置 1. 引言:腾讯开源的轻量级高性能翻译模型 随着全球化进程加速,跨语言沟通需求日益增长。传统云端翻译服务虽功能强大,但在延迟、隐私和离线场景下存在明显短板。为此,腾讯…

混元翻译1.5实战:电商商品描述多语言转换

混元翻译1.5实战:电商商品描述多语言转换 随着跨境电商的迅猛发展,高质量、低延迟的多语言翻译能力已成为平台提升用户体验和转化率的关键。然而,通用翻译模型在面对商品标题、属性描述、营销文案等结构化文本时,常出现术语不准、…

Spring Boot文件上传

5.3.1文件上传 开发Web应用时,文件上传是很常见的一个需求浏览器通过表单形式将文件以流的形式传递给服务器,服务器再对上传的数据解析处理。下面我们通过一个案例讲解如何使用SpringBoot实现文件上传,具体步骤如下。 1.编写文件上传的表单…

STM32CubeMX安装包Mac版多用户权限配置指南

如何让团队共享一台 Mac 开发 STM32?STM32CubeMX 多用户权限配置实战 你有没有遇到过这样的场景:实验室只有一台性能强劲的 Mac,但好几个同学都要用它开发 STM32 项目。结果发现,只有当初安装 STM32CubeMX 的那个账号能正常打开…

HY-MT1.5为何选择4090D?单卡部署算力适配深度解析

HY-MT1.5为何选择4090D?单卡部署算力适配深度解析 随着大模型在翻译领域的持续突破,高效、低成本的推理部署成为落地关键。腾讯开源的混元翻译大模型HY-MT1.5系列,凭借其在多语言支持、翻译质量与边缘部署能力上的平衡,迅速引起业…

PDF-Extract-Kit备份恢复:数据处理的安全保障

PDF-Extract-Kit备份恢复:数据处理的安全保障 1. 引言 在现代文档数字化和智能信息提取的场景中,PDF 文件作为最常见、最通用的文档格式之一,承载着大量关键数据。然而,在使用自动化工具进行内容提取时,数据丢失、处…

HY-MT1.5-1.8B量化后精度保持技术揭秘

HY-MT1.5-1.8B量化后精度保持技术揭秘 随着多语言交流需求的不断增长,高效、精准且可部署于边缘设备的翻译模型成为AI落地的关键。腾讯开源的混元翻译大模型HY-MT1.5系列,凭借其在性能与效率之间的出色平衡,迅速引起业界关注。其中&#xff…

HY-MT1.5-1.8B边缘计算:车载系统实时翻译

HY-MT1.5-1.8B边缘计算:车载系统实时翻译 1. 引言 随着智能汽车和车联网技术的快速发展,多语言实时翻译已成为提升驾乘体验的重要功能。在跨国出行、跨境物流或国际会议接驳等场景中,驾驶员与乘客之间常面临语言沟通障碍。传统云端翻译方案…

腾讯HY-MT1.5应用:多语言客服系统搭建教程

腾讯HY-MT1.5应用:多语言客服系统搭建教程 在当今全球化业务快速发展的背景下,跨语言沟通已成为企业服务不可或缺的一环。尤其是在电商、金融、旅游等行业,客户支持需要覆盖多种语言,传统人工翻译成本高、响应慢,难以…

小模型大作为:HY-MT1.5-1.8B应用案例集锦

小模型大作为:HY-MT1.5-1.8B应用案例集锦 在AI翻译领域,大模型往往被视为性能保障的代名词。然而,随着边缘计算和实时交互需求的爆发式增长,轻量高效的小模型正成为落地场景中的“隐形冠军”。腾讯开源的混元翻译模型 1.5 版本&a…

从零实现GRBL移植:STM32开发实战案例

从零实现GRBL移植:STM32开发实战技术深度解析当CNC遇上ARM:为什么我们不再满足于AVR?你有没有遇到过这样的场景?一台基于Arduino的3D打印机在高速打印复杂模型时突然抖动,轨迹偏移;或者一台老式雕刻机执行长…

多语言网站本地化:HY-MT1.5实战案例

多语言网站本地化:HY-MT1.5实战案例 随着全球化业务的不断扩展,多语言网站的本地化需求日益增长。传统翻译服务在成本、延迟和定制化方面存在诸多限制,尤其在面对混合语言、专业术语或格式保留等复杂场景时表现不佳。腾讯开源的混元翻译大模…

openmv与stm32通信配置流程:系统学习第一步

OpenMV与STM32通信配置实战:从零搭建视觉控制系统的第一步你有没有遇到过这样的场景?想做一个能“看”的机器人——比如自动追踪小车、颜色分拣臂,或者手势识别装置。但当你试图在STM32上直接处理摄像头数据时,却发现帧率低得可怜…

LCD Image Converter入门必看:超详细版使用说明

从像素到代码:如何用 LCD Image Converter 高效打通嵌入式图形开发链路你有没有遇到过这样的场景?UI设计师甩来一个精美的PNG图标,你满怀信心地打开Keil,想把它“贴”到OLED屏幕上——结果发现,MCU根本不认识PNG。手动…

LED驱动电路项目应用:5V供电下的小型化设计

如何在5V供电下打造超小型LED驱动电路?实战设计全解析你有没有遇到过这样的场景:想给一款TWS耳机仓加个呼吸灯,却发现PCB上只剩下一小块空地;或者为智能手环设计背光时,发现传统电源方案发热严重、体积臃肿&#xff1f…

Spring Boot整合Redisson的两种方式

项目场景 Spring Boot整合Redisson的两种方式,方式一直接使用yml配置,方式二创建RedissonConfig配置类。前言redisson和redis区别: Redis是一个开源的内存数据库,支持多种数据类型,如字符串、哈希、列表、集合和有序集…

腾讯开源HY-MT1.5教程:上下文感知翻译实现

腾讯开源HY-MT1.5教程:上下文感知翻译实现 1. 引言 随着全球化进程的加速,高质量、多语言互译需求日益增长。传统翻译模型在面对混合语言、专业术语和上下文依赖等复杂场景时,往往表现乏力。为此,腾讯推出了开源翻译大模型 HY-M…

Keil5安装配置步骤详解:适合初学者的完整指南

从零开始搭建Keil5开发环境:嵌入式工程师的第一步 你是否刚接触单片机,面对一堆专业术语感到无从下手? “MDK”、“DFP”、“Arm Compiler”……这些词听起来像天书? 别担心,每个嵌入式大神都是从 安装Keil5 这一…