2014-09-05
问题:请根据题干描述你的算法,有以下树形结构的文本数据:
部门A 职员1 职员2 部门B 职员3 职员4 部门C 职员5 职员6 部门A 职员1 职员2 部门B 职员3 职员4部门C 职员5 职员6
它们用最常用的table符号标识其数据结构,请使用PHP计算出每条数据的路径、是否是叶子节点并导入一张邻接表。
答案:
//使用换行符号分割数组 $arr = explode(PHP_EOL, PHP_EOL . $str); //用来存储路径的数组 $pathArr = array(); //储存结果的数组 $reArr = array(); //辅助变量 $lastPos = $lastPosPre = 0; foreach ($arr as $id => $v){ ///t出现的次数 $lastPos = strrpos ($v, "/t"); $lastPos = ($lastPos === FALSE)?0:$lastPos+1; //将路径压入数组 $pathArr[$lastPos] = $id; //计算出当前路径 $path = array_slice ($pathArr, 0, $lastPos); //计算父级id $pid = (int) isset ($pathArr[$lastPos - 1]) ? $pathArr[$lastPos - 1] : 0; //首次循环丢弃 if ($id == 0){continue;} //要写入数据库的数据 $reArr[$id] = array( 'id' => $id, 'pid' => $pid, 'is_leaf' => 1, 'path' => '/' . implode('/', $path), 'name' => ltrim($v, "/t") ); //是否叶子节点 if ($lastPos > $lastPosPre) { $reArr[$id-1]['is_leaf'] = 0; } //上一节循环中,/t出现的次数 $lastPosPre = $lastPos; } //使用换行符号分割数组$arr = explode(PHP_EOL, PHP_EOL . $str);//用来存储路径的数组$pathArr = array();//储存结果的数组$reArr = array();//辅助变量$lastPos = $lastPosPre = 0;foreach ($arr as $id => $v){ ///t出现的次数 $lastPos = strrpos ($v, "/t"); $lastPos = ($lastPos === FALSE)?0:$lastPos+1; //将路径压入数组 $pathArr[$lastPos] = $id; //计算出当前路径 $path = array_slice ($pathArr, 0, $lastPos); //计算父级id $pid = (int) isset ($pathArr[$lastPos - 1]) ? $pathArr[$lastPos - 1] : 0; //首次循环丢弃 if ($id == 0){continue;} //要写入数据库的数据 $reArr[$id] = array( 'id' => $id, 'pid' => $pid, 'is_leaf' => 1, 'path' => '/' . implode('/', $path), 'name' => ltrim($v, "/t") ); //是否叶子节点 if ($lastPos > $lastPosPre) { $reArr[$id-1]['is_leaf'] = 0; } //上一节循环中,/t出现的次数 $lastPosPre = $lastPos;}
这份答案,可以导入无限深的树形结构数据。不过未经优化,等已有有时间再琢磨琢磨。
1
CI框架连接数据库配置操作以及多数据库操作
09-05
2
asp 简单读取数据表并列出来 ASP如何快速从数据库读取大量数据
05-17
3
C语言关键字及其解释介绍 C语言32个关键字详解
04-05
4
C语言中sizeof是什么意思 c语言里sizeof怎样用法详解
04-26
5
PHP中的魔术方法 :__construct, __destruct , __call, __callStatic,__get, __set, __isset, __unset , __sleep,
09-05
6
将视频设置为Android手机开机动画的教程
12-11
7
PHP中的(++i)前缀自增 和 (i++)后缀自增
09-05
8
最简单的asp登陆界面代码 asp登陆界面源代码详细介绍
04-12
常用dos命令及语法
2014-09-27
PHP中include和require区别之我见
2014-09-05
如何安装PHPstorm并配置方法教程 phpstorm安装后要进行哪些配置
2017-05-03
php递归返回值的问题
2014-09-05
单片机编程好学吗?单片机初学者怎样看懂代码
2022-03-21
PHP 教程之如何使用BLOB存取图片信息实例
2014-09-05
学ug编程如何快速入门?
2022-03-17
PHP数组函数array
2014-09-05
学习使用C语言/C++编程的7个步骤!超赞~
2022-03-20
零基础的初学者怎样学习java,或者应该先学什么?
2022-03-21
坦克沙盒游戏手机版(坦克物理模拟)下载v9.0 安卓版
其它手游 241.7MB
下载
太空人抽卡对决手机版下载v1.6 安卓版
其它手游 77.61MB
下载
棕熊露营旅行游戏下载v1.1.0 安卓版
其它手游 32.94MB
下载
回家的猫游戏下载v2.5.18 安卓版
角色扮演 105.86MB
下载
蜗牛鲍勃3游戏(snail bob 3)下载v1.0.34 安卓版
其它手游 96.55MB
下载
snail bob3最新版下载v1.0.34 安卓版
其它手游 96.55MB
下载
西梅小说手机版v1.0
其它手游 24.36MB
下载
超级舰队3k破解版下载v10.3 安卓最新版
策略塔防 100.64MB
下载房间的秘密2起点官方版下载v1.2.4.df926432 安卓版
下载
葫芦娃tv版小y游戏下载v3.0.8 安卓版
下载
葫芦娃tv版渠道游戏下载v3.0.8 安卓版
下载
足球大玩家手游下载v1.224.6 安卓最新版
下载
辉烬embers手游官方下载v1.0.0 安卓版
下载
代号辉烬手游下载v1.0.0 安卓版
下载
远光84手游下载v1.1.1.3.1612300 安卓版
下载
逆战助手app下载v3.15.0 安卓版
下载