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. 用count sql做jmeter的while条件

    ${__groovy(vars.get("pboc_req_record_counter_1") == "Invalid"  || vars.get(" ...

  2. Centos 7最小化安装部署PostgreSQL

    安装 sh-4.2# yum install https://download.postgresql.org/pub/repos/yum/11/redhat/rhel-7-x86_64/pgdg-ce ...

  3. linux下生成00 01 02..99的这些数

    [root@localhost ~]# seq -s " " -w 9901 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 ...

  4. Ubuntu编译Protobuf(Base tensorflow-12)报错

    报错1: dogepool@ubuntu-server:~/dogecoin$ ./autogen.sh./autogen.sh: 50: ./autogen.sh: autoreconf: not ...

  5. Unity-使用面向对象的思想

    在做游戏之初,老师曾经说过要用面向对象的思想去做.当时满口答应,应为学了一点C#的原因感觉面向对象很简单嘛,但是事实上在做游戏的过程中,为了赶进度我的代码写的很冗余,很乱.这就导致了我不得不重新修改. ...

  6. 利用 JMetal 实现大规模聚类问题的研究(二) JMetal代码总览

    之前完成了导入JMetal到自己的工程这一步. 在开始我们研究的问题之前,我们先对JMetal的源代码一个全局的认识. JMetal很好地利用了面向对象的特性,对所有的优化问题做了高度的抽象,建议有空 ...

  7. JAVA核心技术I---JAVA基础知识(格式化相关类)

    一:格式化相关类 (一)java.text包java.text.Format的子类 –NumberFormat:数字格式化,抽象类 DecimalFormat –MessageFormat:字符串格式 ...

  8. 设计模式---接口隔离模式之门面模式(Façade)

    前提:接口隔离模式 在组建构建过程中,某些接口之间直接的依赖常常会带来很多问题.甚至根本无法实现.采用添加一层间接接口(稳定的),来隔离本来相互紧密关联的接口是一种常见的解决方案. 典型模式: 门面模 ...

  9. 8.Hystrix-Feign配置服务降级

    项目中用到Feign调用服务端方法并做服务降级处理 1.application.properties配置: feign.hystrix.enabled=true 2.pom: <!--feign ...

  10. Kafka技术内幕 读书笔记之(五) 协调者——消费组状态机

    协调者保存的消费组元数据中记录了消费组的状态机 , 消费组状态机的转换主要发生在“加入组请求”和“同步组请求”的处理过程中 .协调者处理“离开消费组请求”“迁移消费组请求”“心跳请求” “提交偏移量请 ...