ARTS:

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

Algorithm

【leetcode】521. Longest Uncommon Subsequence I(最长不寻常的序列 I)

https://leetcode.com/problems/longest-uncommon-subsequence-i/

1)problem

给定一组两个字符串,您需要找到这组两个字符串中最长的不常见子序列。最长的不常见子序列定义为其中一个字符串的最长子序列,而此子序列不应是其他字符串的任何子序列。

子序列是通过删除一些字符而不更改其余元素的顺序,从一个序列派生的序列。一般来说,任何字符串都是其自身的子序列,而空字符串则是任何字符串的子序列。

输入将是两个字符串,输出需要是最长的不常见子序列的长度。如果不存在最长的不常见子序列,则返回-1。

2)answer

判断两字符串是否相等,如果相等就返回-1,不相等就返回较长的字符串长度

3)solution

class Solution(object):
    def findLUSlength(self, a, b):
        """
        :type a: str
        :type b: str
        :rtype: int
        """
        if len(a) != len(b):
            return max(len(a),len(b))
        if a==b:
            return -1
        else:
            return len(a)

if __name__ == '__main__':
    s = Solution()
    print s.findLUSlength( "aba", "cdc")

Review

【漏洞挖掘】扫描端口

1)场景

快速端口扫描

2)问题难点

python socket使用

https://docs.python.org/3/library/socket.html

3)解决问题的方法

  • TCP全连接扫描
socket.gethostbyname(hostname) :这个函数将主机名换换为IP地址,如              www.syngress.com将会返回IPv4地址为69.163.177.2。

socket.gethostbyaddr(ip_address) :这个函数传入一个IP地址将返回一个元组,                  其中包含主机名,别名列表和同一接口的IP地址列表。

socket.socket([family[, type[, proto]]]) :这个函数将产生一个新的socket,通过给定的socket    地址簇和socket类型,地址簇的可以是AF_INET(默认),AF_INET6或者是AF_UNIX,另外,socket类型可以为一个TCP套接字即SOCK_STREAM(默认),或者是UDP套    接字即SOCK_DGRAM,或者其他的套接字类型。最后协议号通常为零,在大多数    情况下省略不写。

socket.create_connection(address[, timeout[, source_address]] :这个函数传入一个包含IP地    址和端口号的二元元组返回一个socket对象,此外还可以选择超时重连。(注:这个    函数比socket.connect()更加高级可以兼容IPv4和IPv6)。

4)方法细节

# coding=UTF-8
import optparse
import socket

def connScan(tgtHost, tgtPort):
    try:
        connSkt = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        connSkt.connect((tgtHost, tgtPort))   # 向指定IP和端口发送请求
        connSkt.send('ViolentPython\r\n')     # 发送内容
        results = connSkt.recv(100)           # 接收100个字节的回显数据
        print('[+]%d/tcp open' % tgtPort)
        print('[+]' + str(results))
        connSkt.close()
    except:
        print('[-]%d/tcp close' % tgtPort)

def portScan(tgtHost, tgtPorts):
    try:
        tgtIp = socket.gethostbyname(tgtHost)   # 这个函数将主机名换换为IP地址
    except Exception as e:
        print("[-] Cannot resolve '%s' " % tgtHost)
        return
    try:
        tgtName = socket.gethostbyaddr(tgtIp)   # 传入IP地址,返回一个元祖,主机名、别名、同一接口的IP列表
        print('\n[+] Scan Results for:%s' % tgtName[0])
    except:
        print('\n[+] Scan Results for:%s' % tgtIp)
    socket.setdefaulttimeout(1)    # 重连时间
    for tgtPort in tgtPorts:
        print('Scanning port' + str(tgtPort))
        connScan(tgtHost, int(tgtPort))   # 连接端口判断函数

def main():
    parser = optparse.OptionParser('usage%prog -H <target host> -p <target host>')
    parser.add_option('-H', dest='tgtHost', type='string', help='specify target host')
    parser.add_option('-p', dest = 'tgtPort', type='int', help='specify target port')
    options, args = parser.parse_args()
    if options.tgtHost is None or options.tgtPort is None:
        print(parser.usage)
        exit(0)
    else:
        tgtHost = options.tgtHost
        tgtPort = options.tgtPort
    args.append(tgtPort)
    portScan(tgtHost, args)

if __name__ == '__main__':
    main()

Tip

【安全开发】vc++调用exe获取输出信息

1)场景

把命令行结果输入到管道中,exe的输出信息都存在里面,然后读取出来。

2)问题难点

3)解决思路

CreatePipe() //创建匿名管道

CreateProcess() // 启动进程

ReadFile() // 读取管道内容

4)方法细节

vc++调用exe获取输出信息

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

Share

【业务】极客时间-左耳听风-程序员攻略-程序员修养

1)场景

程序员素养

2)问题难点

需要具备的基础品质和能力

3)解决思路

英文能力
问问题的能力
写代码的修养
安全防范
软件工程和上线
附录:编程规范
 编程语言相关
 前端开发相关
 移动端相关
 API 相关
 开发工具相关

4)方法细节

极客时间-左耳听风-程序员攻略-程序员修养

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

【ARTS】01_14_左耳听风-20190211~20190217的更多相关文章

  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_10_左耳听风-20190114~20190120

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

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

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

  9. 【ARTS】01_08_左耳听风-20181231~20190106

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

随机推荐

  1. SVN提交前准备

    操作步骤1: 操作步骤2: 操作步骤3: 操作步骤4: 操作步骤5: 操作步骤6:查看 操作步骤7:ignore 操作步骤8:直接提交项目

  2. python APScheduler

    简介 APScheduler基于Quartz的一个Python定时任务框架,实现了Quartz的所有功能,使用起来十分方便.提供了基于日期.固定时间间隔以及crontab类型的任务,并且可以持久化任务 ...

  3. java中用jdom创建xml文档/将数据写入XML中

    import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; i ...

  4. FastDFS与springboot整合例子

    余庆先生提供了一个Java客户端,但是作为一个C程序员,写的java代码可想而知.而且已经很久不维护了. 这里推荐一个开源的FastDFS客户端,支持最新的SpringBoot2.0. 配置使用极为简 ...

  5. 能使 Oracle 索引失效的六大限制条件【转】

    . 引用自: http://www.cnblogs.com/orientsun/archive/2012/07/05/2577351.html  总结得非常到位 Oracle 索引的目标是避免全表扫描 ...

  6. jQuery使用(四):DOM操作之查找兄弟元素和父级元素

    查找兄弟元素 向下查找兄弟元素 next() nextAll() nextUntil() 向上查找兄弟元素 prev() prevAll() prevUntil() 查找所有兄弟元素 siblings ...

  7. json 模块 与 pickle 模块

    1 import json 3 dic={'name':'alvin','age':23,'sex':'male'} 4 print(type(dic))#<class 'dict'> 6 ...

  8. webpack 内存溢出 Allocation failed - JavaScript heap out of memory

    项目中,当组件文件过多,webpack-dev-server 编译时,容易内存溢出, 在 \node_modules\.bin\webpack-dev-server.cmd 加以下红色配置,暂可解决 ...

  9. 【由浅入深理解java集合】(三)——集合 List

    第一篇文章中介绍了List集合的一些通用知识.本篇文章将集中介绍List集合相比Collection接口增加的一些重要功能以及List集合的两个重要子类ArrayList及LinkedList. 一. ...

  10. EF 事物Transaction简单操作

    /// <summary> /// 申请提现 /// </summary> /// <param name="userId">用户id</ ...