码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【刷题心得】双指针法|HashSet<T>


    题目

    1 概念梳理

    1.1 ISet HashSet

    包含不重复元素的集合称为“集set”。.NET Framework包含两个集HashSet和SortedSet,其中HashSet包含不重复元素的无序列表,SortedSet包含不重复元素的有序列表。

    ISet接口提供的方法可以创建合集,交集。

    1.2 Char.IsDigit()

    参考:C# Char.IsDigit()用法及代码示例 - 纯净天空 (vimsky.com)

    是一种检查Unicode字符是否可以归类为十进制数,有两种:

    Char.IsDigti(Char)——检查指定的字符是否为十进制数

    Char.IsDigti(String, Int)——指定位置的指定字符串是否与十进制数匹配

    1.3 数字问题,去除前导0

    去除前导零的意思就是,有时经过判断后输出的必须是有实际意义的数字,那么“01”“0001”与1意义相同。所以需要加上一步”判断是否为0且去除“的操作。

    1.4 对HashSet的操作

    C# HashSet 用法_IT技术猿猴的博客-CSDN博客_c# hashset

    点入链接,直接回顾一下C#中哈希添加和删除清空等修改操作。

    1.5 正则表达式

    参考:

    正则表达式的一些术语

    包括有a到z之间的字母,还有一些特殊字符。例如这道题后面还想除了一种解法,但是很奇怪用时会超出。

    2 解题

    老老实实用双指针,最后去除前导零就行。

    1. public class Solution {
    2. public int NumDifferentIntegers(string word) {
    3. HashSet<string> str = new HashSet<string>();
    4. int n = word.Length;
    5. int p1, p2=0;
    6. while(true) {
    7. while(p2
    8. p2++; //until:
    9. }
    10. if(p2==n) {
    11. break;
    12. }
    13. p1=p2;
    14. while(p2
    15. p2++;
    16. }
    17. while(p1+1'0') {
    18. p1++;
    19. }
    20. str.Add(word.Substring(p1, p2 - p1));
    21. }
    22. return str.Count;
    23. }
    24. }

    另外在力扣网还看到了用正则巧妙地做的答案:[Java/C++] 简单模拟题 - 字符串中不同整数的数目 - 力扣(LeetCode)

    1. class Solution {
    2. public int numDifferentIntegers(String word) {
    3. Set set = new HashSet<>();
    4. for (String str : word.split("[a-z]+")) if (str.length() > 0) set.add(str.replaceAll("^0+",""));
    5. return set.size();
    6. }
    7. }

  • 相关阅读:
    OOM和JVM最详细介绍
    联通边缘AI:打造“职业技能”,助力行业高质量发展
    Vue源码之数据响应式
    Redis对象系统
    12000条招聘数据告诉Python的学习方向和就业方向
    Temu、Shopee、Lazada等跨境电商流量如何提升?买家号如何批量养号?
    BeanDefinitionStoreException: Failed to read candidate component class
    第三天:配置+运行代码+改个保存键
    迷茫6连,这就是测试人毕业5年后的真实写照吗?
    二十四节气-立冬文案、海报。万物收藏,冬之伊始。
  • 原文地址:https://blog.csdn.net/qq_41835314/article/details/128201978
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号