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. python自动化开发-[第一天]-练习题

    1.使用while循环输入 1 2 3 4 5 6 8 9 10 i = 1 while i < 11: if i == 7: i += 1 continue print (i) i += 1 ...

  2. 信用评分卡 (part 2of 7)

    python信用评分卡(附代码,博主录制) https://study.163.com/course/introduction.htm?courseId=1005214003&utm_camp ...

  3. docker swarm(当前官网示例)

    介绍 Docker Swarm 是 Docker 公司推出的官方容器集群平台,基于 Go 语言实现 作为容器集群管理器,Swarm 最大的优势之一就是 100% 支持标准的 Docker API.各种 ...

  4. SQL记录-ORACLE 12C初体验

    1.部署 2.使用

  5. layui(四)——table组件常见用法总结

    table是 layui 最核心的组成之一.它用于对表格进行一些列功能和动态化数据操作,涵盖了日常业务所涉及的几乎全部需求.支持固定表头.固定行.固定列左/列右,支持拖拽改变列宽度,支持排序,支持多级 ...

  6. Web APi入门之Self-Host寄宿及路由原理

    前言 刚开始表面上感觉Web API内容似乎没什么,也就是返回JSON数据,事实上远非我所想,不去研究不知道,其中的水还是比较深,那又如何,一步一个脚印来学习都将迎刃而解. Self-Host 我们知 ...

  7. PHP索引数组+unset使用不当导致的问题

    转自先知社区 https://xz.aliyun.com/t/2443 0x00前言 通常网站后台可以配置允许上传附件的文件类型,一般登录后台,添加php类型即可上传php文件getshell.但是, ...

  8. Nginx 学习笔记(十)介绍HTTP / 2服务器推送(译)

    原文地址:https://www.nginx.com/blog/nginx-1-13-9-http2-server-push/ 我们很高兴地宣布,2018年2月20日发布的NGINX 1.13.9支持 ...

  9. Android 常见异常及解决办法

    Ø  前言 本文主要记录 Android 的常见异常及解决办法,以备以后遇到相同问题时可以快速解决. 1.   java.lang.NullPointerException: Attempt to i ...

  10. JS创建对象之稳妥构造函数模式

    所谓稳妥对象,指的是没有公共属性,而且其方法也不引用this的对象 function Person(name, age, job) { // 创建要返回的对象 var o = new Object() ...