当前位置:首页 > 每日看点 > 正文内容

无意中发现技术主管写的代码,大家帮忙看看什么水平?

卡卷网1年前 (2024-11-19)每日看点247

虽然很多答主用了诸如“典范级”、“心旷神怡” 的形容, 赞美这段代码, 但这里, 出于技术讨论的动机, 我说说不同看法.

  1. 栈, 如果善于利用栈来处理树结构, 那么可以写出更简洁的代码, 根本不需要 recuresiveFn 这种方法.
  2. 泛型, 如果善于利用泛型, 那么可以写出更通用的代码,而不是耦合于某一种类型。
  3. 算法复杂度, 这段代码的时间复杂度是 N*N , 典型的暴力算法
  4. 代码结构, 写这段代码的人, 虽然有“拆分冗长逻辑为一个方法“ 的意识, 但是, 就其解决的问题而言, 代码可以更简洁.
  5. 命名,TreeUtil 是一个很“泛”的命名, 可是其内容中的 MenuTreeObject 却很“具体 ”, 两个 “域” 不匹配. (封面与内容不匹配)
  6. 灵性, 一段代码可以反映其作者在编写时的内心状态, 这位技术主管当时的状态应该不太好, 合理猜测公司加班情况比较严重.


这里给出我的代码方案, 第一版是时间复杂度 O(N^2) 的版本

interface ITreeNode<T extends ITreeNode<T>> { T parent(); void setChildren(List<T> children); List<T> getChildren(); }


class TreeUtil { public static <T extends ITreeNode<T>> List<T> listToTree(List<T> list) { var roots = list.stream() .filter(n -> n.parent() == null) .collect(Collectors.toList()); var stack = roots.stream().collect(Collectors.toCollection(Stack::new)); while (!stack.isEmpty()) { var node = stack.pop(); //每一个元素都需要跟其他所有元素比较,时间复杂度 N*N node.setChildren( list.stream() .filter(n -> n.parent() != null) .filter(n -> n.parent().equals(node)) .collect(Collectors.toList())); node.getChildren().forEach(stack::push); } return roots; } }


第二版利用动态规划的思想, 分解出“自顶向下构建树”的子问题:“给定一个节点,其子节点有哪些”。

只需一次遍历,缓存每一个节点的 父子关系 ,即可得到每个节点,对于这个子问题的结果。

之后便可以自顶向下地构建树。 在构建过程中,每处理一个节点,都是直接从缓存取其子节点,没有重复计算(不需要重复访问不相关的节点),复杂度从平方级降为线性。

class TreeUtil { public static <T extends ITreeNode<T>> List<T> listToTree2(List<T> list) { //第一次遍历: 记录节点间的父子关系 var relations = new HashMap<T, List<T>>(); for (T node : list) { List<T> relation = relations.computeIfAbsent(node.parent(), (p) -> new LinkedList<>()); relation.add(node); } var roots = relations.get(null); //父节点为null的即为根节点 //第二次遍历: 根据父子关系建立树 var stack = roots.stream().collect(Collectors.toCollection(Stack::new)); while (!stack.isEmpty()) { T node = stack.pop(); node.setChildren(relations.getOrDefault(node, Collections.emptyList())); stack.addAll(node.getChildren()); } return roots; } }


下面是测试代码:

static class MenuItem implements ITreeNode<MenuItem> { private Integer id; private String name; private Integer parentId; public MenuItem(Integer id) { this.id = id; } public MenuItem(Integer id, String name, Integer parentId) { this.id = id; this.name = name; this.parentId = parentId; } @Getter @Setter private List<MenuItem> children; @Override public MenuItem parent() { return parentId == null ? null : new MenuItem(parentId); } @Override public boolean equals(Object o) { return o instanceof MenuItem && Objects.equals(id, ((MenuItem) o).id); } @Override public int hashCode() { return Objects.hash(id); } }


public static void main(String[] args) { List<MenuItem> menuList = Arrays.asList( new MenuItem(1, "一级菜单", null), new MenuItem(2, "二级菜单1", 1), new MenuItem(3, "二级菜单2", 1), new MenuItem(3, "三级菜单1", 2), new MenuItem(4, "三级菜单2", 2) ); List<MenuItem> menuTree = TreeUtil.listToTree2(menuList); System.out.println(menuTree); }

运行结果如下:

无意中发现技术主管写的代码,大家帮忙看看什么水平?  第1张

扫描二维码推送至手机访问。

版权声明:本文由卡卷网发布,如需转载请注明出处。

本文链接:https://www.kajuan.net/ttnews/2024/11/949.html

分享给朋友:

相关文章

4499 元起的荣耀Magic7 系列实际使用体验怎么样,值得入手吗?

全是软文。。。。。。不过我买了,标准版。为什么买荣耀:屏幕看着舒服,玩游戏选择大屏,超声波指纹解锁。其它,系统、续航、充电、拍照,不是最强,但均衡下来短板都不是很短。其它米OV,IQ、一加,都看了,预算有限,米OV的小屏不感兴趣,OPPO硬...

无人机真的是中国领先吗?

无人机真的是中国领先吗?

巧了这是。捡到了一台大疆。应该是别人飞丢的。在草丛中泡过水,轴承锈死,电池鼓涨已,经没有维修价值了。但作为玩电子的,免不了要把它解剖,研究一番。那么,我们看看它的国产化率能有多少吧。图片说话:解释一下吧。图一,高通 美国图二,MPS: 美国...

闲鱼上为什么会有人问都不问直接下单?

我去年卖一个荣耀90,挂的2200,最终成交2137.5元。对方是一个高高壮壮的西北口音,要求的自取。大概我吃过午饭,约了旁边的商场,那里有荣耀售后。见了面,先看了手机,试了好一会儿,各种测试,没问题。然后去了商场二楼的荣耀售后,让人家售后...

如何看待 Luv Letter 表示影视飓风专业性实在是让人失望?

一点儿新进展,另外以下有部分需要关注对于统一变量的问题。这个我在对比上面有写小字解释,我在一开始使用ffmpeg来控制变量。但是发现了不少问题,比如因为遗留bug,会强制将非整数帧的素材转码为VFR导致无法正确帧间对比,因此不考虑,同时尽量...

本专业是电气的,请问入门plc 必须要从电工接线开始吗,我怕被公司骗了,想请教各位?

本专业是电气的,请问入门plc 必须要从电工接线开始吗,我怕被公司骗了,想请教各位?

开关接线图PART 01一开单控开关接线图二三开连体单控开关接线图四开连体单控开关接线图一开五孔单控插座接线图二开五孔单控插座接线图一开双控开关接线图二三开单控开关接线图四开单控开关接线图一开五孔单控插座接线图二三开双控开关接线图一开多控开...

为什么程序员们愿意在GitHub上开源自己的成果给别人免费使用和学习?

开源可以垄断。人类最高的权力不是什么国家而是意识形态,能够控制别人的思维方式。你把你的东西开源出来了,其他人就会懒于思考,在这一个思考上使用你的方式。比如容器编排,经过了K8s后谁还会去开发那些奇奇怪怪的编排手段,直接用不就行了。形成了生态...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。