ARTS:

  • Algrothm: leetcode算法题目
  • Review: 阅读并且点评一篇英文技术文章
  • Tip/Techni: 学习一个技术技巧
  • Share: 分享一篇有观点和思考的技术文章

Algorithm

【leetcode】520. Detect Capital

https://leetcode.com/problems/detect-capital/submissions/

1)problem

一句话,你需要判断其中大写字母的使用是否正确。

当下列情况之一成立时,我们将单词中大写字母的用法定义为正确:

  • 这个单词中的所有字母都是大写字母,如“USA”。
  • 这个单词中的所有字母都不是大写字母,如“leetcode”。
  • 如果它有多个字母,只有这个词中的第一个字母是大写字母,如“Google”。

否则,我们定义该单词不以正确的方式使用大写字母。

Example 1:

Input: "USA"
Output: True

Example 2:

Input: "FlaG"
Output: False

注意: 输入将是一个非空单词,由大写和小写拉丁字母组成。

2)answer

  • 把这个单词转换为大写字母,如果和原来字符串对比相等,就返回true
  • 把这个单词转换为小写字母,如果和原来字符串对比相等,就返回true
  • 把这个单词转换为首个字母为大写,如果和原来字符串对比相等,就返回true

否则为False

3)solution

class Solution(object):
    def detectCapitalUse(self, word):
        """
        :type word: str
        :rtype: bool
        """
        if word.upper() == word:
            return True
        elif word.lower() == word:
            return True
        elif word.capitalize() == word:
            return True
        else:
            return False

第二种算法:

class Solution(object):
    def detectCapitalUse(self, word):
        """
        :type word: str
        :rtype: bool
        """

        lowerStr = list(word)
        for i, j in enumerate(lowerStr):
            if j >= 'A' and j <= 'Z':
                lowerStr[i] = chr(ord(j) + (ord('a') - ord('A')))
        if "".join(lowerStr) == word:
            return True

        upperStr = list(word)
        for i,j in enumerate(upperStr):
            if j >='a' and j<='z':
                upperStr[i] = chr(ord(j) - (ord('a') - ord('A')))
        if "".join(upperStr) == word:
            return True

        capitalStr = list(word)
        for x in range(len(word)):
            if x == 0:
                if capitalStr[x] >= 'a' and capitalStr[x] <= 'z':
                    capitalStr[x] = chr(ord(capitalStr[x]) - (ord('a') - ord('A')))
            else:
                if capitalStr[x]>= 'A' and capitalStr[x] <= 'Z':
                    capitalStr[x]  = chr(ord(capitalStr[x]) + (ord('a') - ord('A')))
        if "".join(capitalStr) == word:
            return True
        return False

Review

【漏洞挖掘】多线程扫描

1)场景

端口多线程扫描

2)问题难点

因为每一个socket都有时间延迟,每一个socket扫描都将会耗时几秒钟

3)解决问题的方法

引入Python线程:线程提供了一种同时执行的方式。

4)方法细节

多线程使用方法:

for tgtPort in tgtPorts:
        print('Scanning port ' + str(tgtPort))
        t = threading.Thread(target=connScan, args=(tgtHost, int(tgtPort)))
        t.start()

加锁:creenLock.acquire()

锁打开,信号量将允许线程继续运行然后打印输出,如果锁定,我们将要等到控制信号量的进程释放锁。

释放锁:screenLock.release()

信号量:semaphore是一个内置的计数器

每当调用acquire()时,内置计数器-1
每当调用release()时,内置计数器+1

Tip

【安全开发】Python解析Pcap包类源码学习

1)场景

解析PCAP包,读取里面的关键信息。

2)问题难点

自动化读取

3)解决思路

使用Python搜索关键字筛选出指定的数据包

4)方法细节

Python解析Pcap包类源码学习

https://www.cnblogs.com/17bdw/p/10562213.html

Share

【业务】绕过PALOALTO TRAPS EDR解决方案

1)场景

绕过PALOALTO TRAPS EDR解决方案,运行黑客工具

2)问题难点

无法直接卸载。

3)解决思路

通过fltMC.exe卸载筛选器驱动程序,达到关掉PALOALTO TRAPS服务的目的。

4)方法细节

绕过PALOALTO TRAPS EDR解决方案

https://www.cnblogs.com/17bdw/p/10562347.html

【ARTS】01_15_左耳听风-20190218~20190224的更多相关文章

  1. 【ARTS】01_21_左耳听风-201900401~201900407

    ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...

  2. 【ARTS】01_20_左耳听风-20190325~20190331

    zz## ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 ...

  3. 【ARTS】01_19_左耳听风-20190318~20190324

    ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...

  4. 【ARTS】01_18_左耳听风-20190311~20190317

    ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...

  5. 【ARTS】01_17_左耳听风-20190304~20190310

    ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...

  6. 【ARTS】01_16_左耳听风-20190225~20190303

    ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...

  7. 【ARTS】01_14_左耳听风-20190211~20190217

    ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...

  8. 【ARTS】01_10_左耳听风-20190114~20190120

    ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...

  9. 【ARTS】01_09_左耳听风-20190107~20190113

    ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...

随机推荐

  1. MK-编辑器

    MK-编辑器 MarkdownPad 一款全功能的编辑器,被很多人称赞为windows 平台最好用的markdown编辑器 好用的MK编辑器:Typora 一次打开两个界面 在本文编辑器领域,Vim ...

  2. -bash: /tyrone/jdk/jdk1.8.0_91/bin/java: cannot execute binary file

    问题描述:今天在linux环境下安装了一下JDK,安装成功后,打算输入java -version去测试一下,结果却出错了. 错误信息:-bash: /tyrone/jdk/jdk1.8.0_91/bi ...

  3. SQL语法基础之ALTER语句

    SQL语法基础之ALTER语句 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.查看ALTER的帮助信息 mysql> ? ALTER Many help items fo ...

  4. Docker: 安装配置入门[二]

    一.安装配置启动 1.环境 [root@docker1 ~]# cat /etc/redhat-release CentOS Linux release 7.4.1708 (Core) [root@d ...

  5. EF部分字段更新,忽略为null字段

    一般的更新代码是这样的 public T Update<T>(T entity) where T : ModelBase { var set = this.Set<T>(); ...

  6. jQuery视频格式的验证

    $(document).on('change','#videofile',function() { var file = this.files[0]; if (!/video\/\w+/.test(f ...

  7. excel vlookup简易样例【原】

    vlookup功能 vlookup主要用来做映射,就像java的map一样. 比如我要找id为2的学生对应的名字,那么在F7单元格录入=VLOOKUP(E7,$A$2:$B$4,2,FALSE) 实际 ...

  8. HDU - 6304(2018 Multi-University Training Contest 1) Chiaki Sequence Revisited(数学+思维)

    http://acm.hdu.edu.cn/showproblem.php?pid=6304 题意 给出一个数列的定义,a[1]=a[2]=1,a[n]=a[n-a[n-1]]+a[n-1-a[n-2 ...

  9. ASP.NET Web API 2 使用 AuthorizationFilter(授权过滤器)实现 Basic 认证

    Ø  前言 在 Web 项目中授权认证方式有很多种,本文主要讲述基于 Basic 的认证方式.这是一种比较简单.常见的认证方式,主要是将请求的用户名和密码进行加密后返回给调用方,比较适合采用用户名.密 ...

  10. [译]使用Command模式和MediatR简化你的控制器

    原文 你希望保持你的controller足够简单. 你的controller越来越臃肿,你听说command模式是一个给controller瘦身的解决方案. 但是你不知道command模式是否适合你的 ...