python读取字符串按列分配后按行读出
来源:互联网 发布:淘宝手机详情添加链接 编辑:程序博客网 时间:2024/06/15 14:15
问题:
输入一个字符串和一个数字,数字代表分为几行,需要按照给定的列存储方法存储下来之后按行拼接读出,如:
输入:TNGDWXAZQSCVBK,3
输出:TWQBNDXZSVKGAC
中间转化的时候会形成这样的图形:
T W Q KN D X Z S V BG A C
化为矩阵可能看得更清晰一点:
T 0 W 0 Q 0 BN D X Z S V KG 0 A 0 C 0 0
0是作为空白填充进去的,下面看具体的实现:
#!usr/bin/env python#encoding:utf-8'''__Author__:沂水寒城功能:zigzag_patternT W Q KN D X Z S V BG A C convert("TNGDWXAZQSCVBK", 3) should return "TWQBNDXZSVKGAC".'''def convert_test(one_str,num): ''' ''' mod=len(one_str)%(num+1) if mod==0: cols=(len(one_str)/(num+1))*2 else: cols=(len(one_str)/(num+1))*2+1 rows=num #print 'rows, cols', rows, cols matrix=[] for i in range(rows): matrix.append([0]*cols) one_str_list=list(one_str) for j in range(cols): if j%2==0: for i in range(rows): if len(one_str_list): matrix[i][j]=one_str_list.pop(0) else: matrix[1][j]=one_str_list.pop(0) #print matrix # for one in matrix: # one_list=[str(onec) for onec in one] # print ' '.join(one_list) res='' for one_list in matrix: one_list=[str(one) for one in one_list] res+=''.join(one_list) return ''.join(res.split('0'))if __name__ == '__main__': print convert_test("TNGDWXAZQSCVBK", 3) print convert_test("PAYPALISHIRING", 2) print convert_test("PAYPALISHIRING", 4)
结果如下:
TWQBNDXZSVKGACPPIINAYALSHRIGPLRAAIIIYSNPHG[Finished in 0.3s]
阅读全文
0 0
- python读取字符串按列分配后按行读出
- python读取xml字符串
- Python 读取csv的某列
- Python 读取csv的某列
- Python 读取csv的某列
- 读取txt列,python一行流
- Python修改数据中的字符串数据列
- php读出csv中的每一列
- 关于mybatis读取数据库字段text类型时,读出数据为地址,并不是字符串的问题
- Python按指定列读取csv文件及写文件时的隔行问题
- Python split() 函数 拆分字符串 将字符串转化为列
- Python split() 函数 拆分字符串 将字符串转化为列
- Python split() 函数 拆分字符串 将字符串转化为列
- 批处理读取txt内中文,读出乱码
- python将文件读取为字符串
- python 对csv文件的列的内容读取
- Python读取excel指定列生成指定sql脚本
- Pandas Python读取CSV文件中的某一列
- MFC常用的类及其成员函数简介
- Symfony Security 机制
- xml添加下着重号样式
- RE:JAVA学习-变量,基本数据类型,Scanner
- HDU5699货物运输 (二分+不等式判断)
- python读取字符串按列分配后按行读出
- CodeForces 427D-Match & Catch
- MFC—4个基本类中的成员函数介绍
- Python::两种格式化输出方式
- iOS MesaSQLite数据库简单使用
- MFC中AfxMessageBox和MessageBox的区别
- RDS 在线DDL诡异报错ERROR 1062 (23000): Duplicate entry
- 最小生成生成树计数
- MySQL