题目:
一只小羊跳过了栅栏,两只小样跳过了栅栏,一坨小羊跳过了栅栏…
tn c0afsiwal kes,hwit1r g,npt ttessfu}ua u hmqik e {m, n huiouosarwCniibecesnren.
由题可知,应该是栅栏密码,一般来说,要先去掉空格再分组的,然而这个不要空格之后发现字符串长度只有71,是个素数,不能分组了,所以算上空格的话85~=17*5,要么分17组,要么分5组。这是个解密的过程,先按5组来说吧,需要把每组的相同位置的数依次串起来,即得原文。(逆推的话,也就是原文5个一组,分成了17组,把每组的相同位置的依次串起来),也就是栅栏密码,解密加密过程一样,只是分的组数不一样,分别是两个因数。
>>> s='tn c0afsiwal kes,hwit1r g,npt ttessfu}ua u hmqik e {m, n huiouosarwCniibecesnren.'
>>> print(len(s))
85
>>> for i in range(17):
for j in range(5):
print(s[17*j+i])
每个分组17个,所以是17*j,至于i就是每个分组依次第0个第1个。。。串起来。
(((顺便再看一下,逆推导。
>>> s='the anwser is wctf{C01umnar},if u is a big new,u can help us think more question,tks.'
>>> for i in range(5):
for j in range(17):
print(s[5*j+i])
只需将两个因子的所有位置调换而无需其他改动)))
。。。。回归这个题。。。。
t
h
e
a
n
w
s
e
r
i
s
w
c
t
f
{
C
0
1
u
m
n
a
r
}
,
i
f
u
i
s
a
b
i
g
n
e
w
,
u
c
a
n
h
e
l
p
u
s
t
h
i
n
k
m
o
r
e
q
u
e
s
t
i
o
n
,
t
k
s
.