CTF牛刀小实——聪明的小羊

来源:互联网 发布:linux 安装ant 编辑:程序博客网 时间:2024/04/27 15:07

题目:
一只小羊跳过了栅栏,两只小样跳过了栅栏,一坨小羊跳过了栅栏…

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])

只需将两个因子的所有位置调换而无需其他改动)))

。。。。回归这个题。。。。

theanwseriswctf{C01umnar},ifuisabignew,ucanhelpusthinkmorequestion,tks.
0 0
原创粉丝点击