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. 剑指Offer_编程题_3

    题目描述 输入一个链表,从尾到头打印链表每个节点的值. /** * struct ListNode { * int val; * struct ListNode *next; * ListNode(i ...

  2. dom4j基础教程【转】

    转自 http://blog.csdn.net/whatlonelytear/article/details/42234937 ,但经过大量美化及补充. Dom4j是一个易用的.开源的库,用于XML, ...

  3. [转]Red Hat Linux相关产品iso镜像下载【百度云】

    超强汇总!献上大佬链接:http://www.linuxfly.org/post/659/ 还有一些可用链接: 下面的直接复制到迅雷下载,链接是打不开的. RHEL 5.4 ISO下载http://r ...

  4. Part-Seven

    1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12.

  5. spring整合ActiveMq

    spring整合ActiveMq: 1:依赖的jar包: 2:spring-activemq.xml    的配置: 代码: <?xml version="1.0" enco ...

  6. Spring Boot中使用使用Spring Security和JWT

     目标 1.Token鉴权 2.Restful API 3.Spring Security+JWT 开始 自行新建Spring Boot工程 引入相关依赖 <dependency> < ...

  7. npm与nrm

    npm npm是Node.js 平台的默认包(模块依赖)管理工具 Node Package Manager nrm 一个npm的源管理器(管理工具) 允许快速的在 npm 源间切换 两者关系 npm是 ...

  8. Bitcoin Core钱包客户端的区块数据搬家指南

    最近在饭团(微信中的一个服务号)里教一些朋友学习比特币和区块链技术,为了让大家深刻地理解去中心化网络和钱包等概念,我推荐大家一定要安装经典的Bitcoin Core钱包软件,有些朋友在安装的时候没有留 ...

  9. javascript获取值

    <div id='name'>张三</div> $('#name').val() $(name).val() 以上两个都可以得到值,第一种用的比较多.

  10. MySQL的一些基本命令笔记(1)

    关系型数据库的建模构建块: 1.数据是以行和列的形式存储数据. 2.这一系列的行和列称为表(关系) 3.表中的每一行表示一条记录(元组) 4.表中的每一列表示记录的一个属性 5.一组表组成了数据库 6 ...