ARTS 2019 04 28 (28)

本文深入探讨了LeetCode上的经典题目“字母异位词分组”,对比了三种不同的解决方案:错误的遍历判断法、较优的散列表法以及官方推荐的计数分类法。详细解析了每种方法的实现细节和时间复杂度,旨在帮助读者理解算法设计的核心思想。

ARTS
Algorithm:每周至少做一个leetcode的算法题;
Review:阅读并点评至少一篇英文技术文章;
Tip/Tech:学习至少一个技术技巧;
Share:分享一篇有观点和思考的技术文章;

Algorithm

49. 字母异位词分组

https://leetcode-cn.com/problems/group-anagrams/
先来看看这代码写的,其实就是如果一个数组如果遍历过了就放在集合当中,不进行判断了,但是最坏的情况就是没单词都是单独的异位词,这样就导致了时间复杂度非常大。这样的解法是不对的,会导致时间超时。

public List<List<String>> groupAnagrams(String[] strs) {
   Set<Integer> set = new HashSet<Integer>();
    List<List<String>> res = new LinkedList<>();
    for (int i = 0, len = strs.length; i < len; ++i) {
        if (set.contains(i)) {
            continue;
        }
        List<String> tempList = new LinkedList<>();
        for (int j = i; j < len; ++j) {
            if (!set.contains(j)) {
                boolean result = hashBetterIsAnagram(strs[i], strs[j]);
                if (result) {
                    set.add(j);
                    tempList.add(strs[j]);
                }
            }
        }
        res.add(tempList);
    }
    return res;
}

public boolean hashBetterIsAnagram(String s, String t) {
    int[] first = new int[26];
    for (int i = 0, len = s.length(); i < len; ++i) {
        first[s.charAt(i) - 'a'] ++;
    }
    for (int i = 0, len = t.length(); i < len; ++i) {
        first[t.charAt(i) - 'a'] --;
    }
    for (int i = 0; i < 26; ++i) {
        if (first[i] != 0) {
            return false;
        }
    }
    return true;
}
一个相对正确的解法

用一个散列表,用排序过后的单词作为key,异位词构成的list直接作为value。这样设计就很好的形成了一一对应的关系了。而且代码也行到底很简洁。非常适合阅读,虽然不是最好的时间复杂度,但是已经做到很好了。
时间复杂度:

时间复杂度:O(NK \log K)O(NKlogK),其中 NN 是 strs 的长度,而 KK 是 strs 中字符串的最大长度。当我们遍历每个字符串时,外部循环具有的复杂度为 O(N)O(N)。然后,我们在 O(K \log K)O(KlogK) 的时间内对每个字符串排序。

public List<List<String>> groupAnagrams(String[] strs) {
   // 查找表法
    Map<String, List<String>> map = new HashMap<>();
    for (String str : strs) {
        char[] chars = str.toCharArray();
        Arrays.sort(chars);
        // 将每个字符串对应字符数组经排序后得到的字符串作为该字符串的分类标志
        String flag = String.valueOf(chars);
        List<String> list = map.getOrDefault(flag, new ArrayList<>());
        list.add(str);
        map.put(flag, list);
    }
    return new ArrayList<>(map.values());
}

public boolean hashBetterIsAnagram(String s, String t) {
    int[] first = new int[26];
    for (int i = 0, len = s.length(); i < len; ++i) {
        first[s.charAt(i) - 'a'] ++;
    }
    for (int i = 0, len = t.length(); i < len; ++i) {
        first[t.charAt(i) - 'a'] --;
    }
    for (int i = 0; i < 26; ++i) {
        if (first[i] != 0) {
            return false;
        }
    }
    return true;
}

官方的最佳解答的思想。用计数分类的思想,其实就很想我以前认为的哈希思想。用一个数组在记录每个字母出现的次数
用一个固定的串来作为map的标识,这样全部单词只要遍历一次就够了。Nice

class Solution {
    public List<List<String>> groupAnagrams(String[] strs) {
        if (strs.length == 0) return new ArrayList();
        Map<String, List> ans = new HashMap<String, List>();
        int[] count = new int[26];
        for (String s : strs) {
            Arrays.fill(count, 0);
            for (char c : s.toCharArray()) count[c - 'a']++;

            StringBuilder sb = new StringBuilder("");
            for (int i = 0; i < 26; i++) {
                sb.append('#');
                sb.append(count[i]);
            }
            String key = sb.toString();
            if (!ans.containsKey(key)) ans.put(key, new ArrayList());
            ans.get(key).add(s);
        }
        return new ArrayList(ans.values());
    }
}

Review

Let’s code a TCP/IP stack, 4: TCP Data Flow & Socket API

http://www.saminiir.com/lets-code-tcp-ip-stack-4-tcp-data-flow-socket-api/

  • Transmission Control Block
  • TCP Data Communication
  • TCP Connection Termination
  • Socket API
  • Testing our Socket API
  • Conclusion
  • Sources

这篇说的和传输的数据流有关,我最近一直在想着是不是要用Java把这几篇的文章给实现一遍。

Tip/Tech

通过看JDK的源码,对几种设计模式加深了思考。

Share

https://onezero.medium.com/ctrl-alt-delete-the-planned-obsolescence-of-old-coders-9c5f440ee68

Ctrl-Alt-Delete: The Planned Obsolescence of Old Coders

Old coders never die, they just become middle managers.

老码农过时计划。
这篇文章说的就是有关于年纪大的程序员和命运相关的话题,总得来说就是很多大公司其实更喜欢年纪小的程序员,因为年轻嘛,可以熬夜,加班,扛得住,可是到了三十几岁的,那就危险了,身体不行了,有了家庭,肯定是不会去花那么多时间熬夜了,毕竟高薪也就意味着竞争压力很大,不可能每个公司都养着这么多的人。

<think>好的,我现在需要处理用户的问题:“arts in IT context”。用户提到这可能与IT相关,但具体意图不明确。首先,我要分析用户可能的意图,并确定如何展开搜索和回答。 用户的问题“arts in IT context”中的“arts”可能指的是艺术在信息技术领域中的应用或结合,比如数字艺术、计算机图形学、游戏设计等。也有可能用户误拼写,原本想找的是“ARTS”在IT中的含义,比如某种技术框架或缩写。比如,ARTS可能代表Agile、Robust、Testable、Scalable,或者某个特定的方法论。此外,还有可能是用户想了解信息技术中的文科结合,如人文与技术的交叉领域。 首先,我需要确认“arts”在此处的准确含义。由于用户问题不明确,可能需要覆盖多个可能性。接下来,进行网络搜索,查找“arts in IT context”的相关信息,看看是否有常见的解释或应用领域。 搜索关键词可能包括:“arts in IT meaning”,“ARTS acronym IT”,“digital arts in information technology”,“humanities and arts in IT”等。通过搜索结果,分析常见解释。 根据初步搜索,发现“ARTS”在IT领域可能有几种含义: 1. Agile、Robust、Testable、Scalable:软件开发的指导原则。 2. Algorithmic and Random Testing System:测试方法。 3. 艺术与技术的结合,如数字媒体艺术、游戏设计、用户体验设计等。 需要进一步验证这些信息的准确性,并整理出最相关的内容。同时,检查是否有其他可能的解释,如特定框架、工具或方法论。 接下来,整理信息,按照用户的要求生成回答。回答需要分点,结构清晰,每个方法或步骤间换行,避免使用第一人称和步骤词汇。同时,确保引用内容分散在回答中,不集中在末尾。此外,生成相关问题部分,需基于回答内容提出三个相关问题。 在整理过程中,要注意用户的格式要求,特别是数学公式和代码部分,但当前问题可能不涉及这些内容。但需保持结构,如分节、代码块等,如果有相关内容的话。 最后,生成相关问题时要确保问题与原始问题和回答内容紧密相关,帮助用户进一步探索主题。例如,可能的问题包括ARTS框架的具体应用、数字艺术工具推荐、或艺术与AI结合的例子等。 总结,回答的结构可能包括: 1. ARTS作为缩写或框架的解释。 2. 艺术在IT中的具体应用领域。 3. 跨学科结合的实例。 确保每个部分都有网络搜索的支持,并引用相关来源,但根据用户要求不集中在末尾。同时,最后生成的相关问题需要符合格式要求,使用正确标题,且每个问题编号正确。</think>#### ARTS在IT领域的多重含义与应用场景 --- ### 1. **ARTS作为技术方法论与框架** 在软件开发领域,**ARTS** 通常指代一种工程实践原则,包含以下核心要素: - **A (Agile)**:敏捷开发流程,强调迭代交付与快速响应需求变化。 - **R (Robust)**:鲁棒性设计,确保系统在异常输入或高负载下的稳定性。 - **T (Testable)**:可测试性架构,通过单元测试、集成测试保障代码质量。 - **S (Scalable)**:可扩展性设计,支持系统随业务增长横向/纵向扩展。 **示例代码(测试框架)**: ```python # 使用pytest实现可测试性(T) def test_addition(): assert add(2, 3) == 5, "加法函数测试失败" ``` --- ### 2. **ARTS作为特定技术术语** - **Algorithmic and Random Testing System (ARTS)**:一种结合算法与随机测试的软件验证方法,用于复杂系统的缺陷检测。 - **ARTS-Linux**:实时操作系统扩展,支持高精度定时任务调度。 **数学公式示例**: 随机测试覆盖率计算: $$覆盖率 = \frac{被触发的代码路径数}{总代码路径数} \times 100\%$$ --- ### 3. **艺术与IT的跨学科融合** IT技术为艺术创作与展示提供新工具,典型领域包括: - **数字媒体艺术**:使用编程语言(如Processing)生成交互式视觉作品。 ```processing void setup() { size(800, 600); } void draw() { fill(random(255), random(255), random(255)); ellipse(mouseX, mouseY, 50, 50); } ``` - **游戏开发**:结合3D建模(Blender)与游戏引擎(Unity/Unreal)。 - **用户体验设计(UX)**:通过心理学原理与前端技术优化产品交互流程。 **案例**:NFT(非同质化代币)利用区块链技术实现数字艺术品的唯一性认证与交易。 --- ### 4. **人文艺术在IT教育中的角色** 全球顶尖计算机院校(如MIT Media Lab)开设交叉学科课程: - **计算艺术(Computational Art)**:探索算法生成艺术的理论与实践。 - **数据可视化**:将复杂数据转化为直观图形,依赖设计原则与工具(D3.js、Tableau)。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值