133. Clone Graph

本文详细解析了一种图克隆算法的实现过程,包括节点及其邻接关系的复制。介绍了如何通过两次遍历来完成图中节点及其连接关系的完整复制,并提供了一种使用哈希映射来优化该过程的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


July-03-2019

这个题比较诡异。题里说的unique是指任何VAL是1的点其实都是指向1个。
做法是先走一遍,记录所有的已经存在的node: Node[100]。
复制一遍记录的所有Node,此时复制的只有里面的val,复制出的copyNode的neighbor还没做好,也就是说复制出来的copyNodes之间的指向关系还没建立好。
然后走一遍复制过的所有copyNodes,通过copyNode.val来找到对应的node,然后把node里的所有neighbor加到copyNode的neighbor里:比如neighbor-3要加在copyNode里的是copy[3]
有点绕= =

class Solution {
    public Node cloneGraph(Node node) {
        if (node == null) return null;
        Node[] nodes = fillNodes(node);
        Node[] copies = new Node[101];
        for (int i = 0; i < 101; i ++) {
            if (nodes[i] != null) {
                copies[i] = new Node(nodes[i].val, new ArrayList<>());
            }
        }

        Arrays.stream(copies).forEach(copy -> {
            if (copy != null) {
                nodes[copy.val].neighbors.stream().forEach(realNeighbor -> {
                    copy.neighbors.add(copies[realNeighbor.val]);
                });
            }
        });
        
        return copies[node.val];
        
    }
    
    public Node[] fillNodes(Node node) {
        Node[] nodes = new Node[101];
        boolean[] visited = new boolean[101];
        if (node == null) return nodes;
        ArrayDeque<Node> q = new ArrayDeque<>();
        q.offerLast(node);
        visited[node.val] = true;
        
        while (!q.isEmpty()) {
            Node tempNode = q.pollFirst();
            nodes[tempNode.val] = tempNode;
            tempNode.neighbors.stream()
                .filter(neighbor -> !visited[neighbor.val])
                .forEach(neighbor -> {
                    q.offerLast(neighbor);
                    visited[neighbor.val] = true;
                });
        }
        
        return nodes;
    }
}

四刷。。

这傻屌题都四刷了么。。

public class Solution {
    Map<Integer, UndirectedGraphNode> map = new HashMap<>();
    public UndirectedGraphNode cloneGraph(UndirectedGraphNode node) {
        if (node == null) return null;
    
        if (!map.containsKey(node.label)) {
            map.put(node.label, new UndirectedGraphNode(node.label));
        } 
        UndirectedGraphNode res = map.get(node.label);
        res.neighbors = new ArrayList<UndirectedGraphNode>();
        
        for (UndirectedGraphNode n : node.neighbors) {
            if (!map.containsKey(n.label)) {
                res.neighbors.add(cloneGraph(n));
            } else {
                res.neighbors.add(map.get(n.label));
            }
        }
        
        return res;
    }
}

转载于:https://www.cnblogs.com/reboot329/p/5871437.html

资源下载链接为: https://pan.quark.cn/s/f989b9092fc5 HttpServletRequestWrapper 是 Java Servlet API 中的一个工具类,位于 javax.servlet.http 包中,用于对 HttpServletRequest 对象进行封装,从而在 Web 应用中实现对 HTTP 请求的拦截、修改或增强等功能。通过继承该类并覆盖相关方法,开发者可以轻松地自定义请求处理逻辑,例如修改请求参数、添加请求头、记录日志等。 参数过滤:在请求到达处理器之前,可以对请求参数进行检查或修改,例如去除 URL 编码、过滤敏感信息或进行安全检查。 请求头操作:可以修改或添加请求头,比如设置自定义的 Content-Type 或添加认证信息。 请求属性扩展:在原始请求的基础上添加自定义属性,供后续处理使用。 日志记录:在处理请求前记录请求信息,如 URL、参数、请求头等,便于调试和监控。 跨域支持:通过添加 CORS 相关的响应头,允许来自不同源的请求。 HttpServletRequestWrapper 通过继承 HttpServletRequest 接口并重写其方法来实现功能。开发者可以在重写的方法中添加自定义逻辑,例如在获取参数时进行过滤,或在读取请求体时进行解密。当调用这些方法时,实际上是调用了包装器中的方法,从而实现了对原始请求的修改或增强。 以下是一个简单的示例,展示如何创建一个用于过滤请求参数的包装器: 在 doFilter 方法中,可以使用 CustomRequestWrapper 包装原始请求: 这样,每当调用 getParameterValues 方法时,都会先经过自定义的过滤逻辑。 HttpServletRequestWrapper 是 Java Web 开发中一个强大的工具,它提供了灵活的扩展性,允许开发者
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值