螺旋加密

描述

Chip和Dale发明了一种文本信息加密技术。他们事先秘密约定好矩阵的行数和列数。接着,将字符按如下方式编码:

1. 所有文本只包含大写字母和空格。

2. 每个字符均赋予一个数值:空格=0,A=1,B=2,……,Y=25,Z=26。

按照下图所示的方式,将每个字符对应数值的5位二进制数依次填入矩阵。最后用0将矩阵补充完整。例如,对于信息“ACM”,行列数均为4时,矩阵将被填充为:

将矩阵中的数字按行连起来形成数字串,完成加密。例子中的信息最终会被加密为:0000110100101100。

输入

一行。首先是两个整数R(1≤R≤20)和C(1≤C≤20),表示行数和列数。之后是一个只包含大写字母和空格的字符串。字符串的长度≤(R*C)/5。R和C之间以及C和字符串之间均用单个空格隔开。

输出

一行,为加密后的二进制串。注意你可能需要用0将矩阵补充完整。

样例输入

4 4 ACM

样例输出

0000110100101100
dicts = [
    "00000", "00001", "00010", "00011", "00100",
    "00101", "00110", "00111", "01000", "01001",
    "01010", "01011", "01100", "01101", "01110",
    "01111", "10000", "10001", "10010", "10011",
    "10100", "10101", "10110", "10111", "11000",
    "11001", "11010"]
to = [0, 1, 1, 0, 0, -1, -1, 0]  # 转向的顺序
s = input()
ind= s.index(' ')
R = int(s[0:ind])
ind2 = s[ind+1:].index(' ')
C = int(s[ind+1:ind+1+ind2])
str = s[ind+2+ind2:]

ans = ''
for i in range(len(str)):
    if str[i] == ' ':
        ans += dicts[0]
    else:
        ans += dicts[ord(str[i]) - ord('A') + 1]
r = x = y = 0
result = [['#'] * 25 for i in range(25)]
for i in range(len(ans)):
    result[x][y] = ans[i]
    # 计算下一步填充的位置
    nextx = x + to[r * 2 + 0]
    nexty = y + to[r * 2 + 1]
    # 出界了,要纠正
    if nextx < 0 or nextx >= R or nexty < 0 or nexty >= C or result[nextx][nexty] != '#':
        r = (r + 1) % 4
        x = x + to[r * 2 + 0]
        y = y + to[r * 2 + 1]
    else:
        x = nextx
        y = nexty

for i in range(R):
    for j in range(C):
        if result[i][j] == '#':
            print('0', end='')
        else:
            print(result[i][j], end='')

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Knight_Ren

资源不易,打赏随意

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值