zoukankan      html  css  js  c++  java
  • z字形变换

    将一个给定字符串根据给定的行数,以从上往下、从左到右进行 Z 字形排列。

    比如输入字符串为 "LEETCODEISHIRING" 行数为 3 时,排列如下:

    L C I R
    E T O E S I I G
    E D H N
    之后,你的输出需要从左往右逐行读取,产生出一个新的字符串,比如:"LCIRETOESIIGEDHN"。

    请你实现这个将字符串进行指定行数变换的函数:

    string convert(string s, int numRows);
    示例 1:

    输入: s = "LEETCODEISHIRING", numRows = 3
    输出: "LCIRETOESIIGEDHN"
    示例 2:

    输入: s = "LEETCODEISHIRING", numRows = 4
    输出: "LDREOEIIECIHNTSG"
    解释:

    L D R
    E O E I I
    E C I H N
    T S G

    第一种方法

    def uniqueMorseRepresentations(words):
        code = [".-", "-...", "-.-.", "-..", ".", "..-.", "--.", "....", "..", ".---", "-.-", ".-..", "--", "-.", "---",
                ".--.", "--.-", ".-.", "...", "-", "..-", "...-", ".--", "-..-", "-.--", "--.."]
        dict = {}
        li = []
        a_asic = ord('a')
        for i in range(26):
            dict[chr(a_asic + i)] = code[i]
        for s in words:
            lis = []
            for y in s:
                lis.append(dict[y.lower()])
            if lis not in li:
                li.append(lis)
        return len(li)
    print(uniqueMorseRepresentations(["gin", "zen", "gig", "msg"]))
    第二种方法
    
    def uniqueMorseRepresentations(words):
        code = [".-", "-...", "-.-.", "-..", ".", "..-.", "--.", "....", "..", ".---", "-.-", ".-..", "--", "-.", "---",
                ".--.", "--.-", ".-.", "...", "-", "..-", "...-", ".--", "-..-", "-.--", "--.."]
        ditc = {}
        li = []
        a_assic = ord('a')
        for i in range(26):
            ditc[chr(a_assic + i)] = code[i]
    
        for s in words:
            lis = []
            for y in s:
                lis.append(ditc[y.lower()])
            if lis not in li:
                li.append(lis)
        return len(li)
    print(uniqueMorseRepresentations(["gin", "zen", "gig", "msg"]))
     
  • 相关阅读:
    webpack打包注意事项
    打印内存, 打印16进制
    c++ 字符集转换
    RegSvr32 加载失败,找不到指定的模块
    错误码设计
    mfc 移动绘制的图形
    获取、设置光标
    c++ 函数中定义函数
    python linux 自动补全 tab.py
    3.4.5节 完整神经网络样例程序
  • 原文地址:https://www.cnblogs.com/an5456/p/10292387.html
Copyright © 2011-2022 走看看