-
-
[原创]2021KCTF秋季赛 偶遇棋痴
-
发表于: 2021-11-26 01:23 15184
-
flag长度14,拆分出半个字节
将flag输入,z为标记
找到字符串,随手在github上搜了一下
发现是lambda演算
查看https://zh.wikipedia.org/wiki/%CE%9B%E6%BC%94%E7%AE%97,大致了解
解析serialization::archive,这里最后一项数输入1以结束程序
观察到前16组数据有规律,(\n\f\x((n)f)(f)x) 重复加上\f\xx)结尾,猜测是输入数字
最后一组是程序输入
将 (\n\f\x((n)f)(f)x) 替换为 i
将 i\f\xx) 替换为 i(space)
同时发现中间有其他重复的结构,也可以替换,其中z是标记,保留
统计连续i的数量
观察结果,发现有点规律
处理数据
得到0756469697B7C416D626461663D7
结合之前flag处理,这里交换endian
pediy{Lambda6}
#include<stdio.h>
int
main(){
int
id
;
int
type
;
while
(
1
){
scanf(
"%d"
,&
id
);
scanf(
"%d"
,&
type
);
switch(
type
){
case
0
:{
int
ch;
int
unk;
scanf(
"%d%d"
,&ch,&unk);
printf(
"\\%c"
,ch);
break
;
}
case
1
:{
printf(
"("
);
break
;
}
case
2
:{
int
ch;
scanf(
"%d"
,&ch);
printf(
"%c)"
,ch);
}
}
int
zero;
scanf(
"%d"
,&zero);
if
(zero !
=
0
){
break
;
}
}
}
#include<stdio.h>
int
main(){
int
id
;
int
type
;
while
(
1
){
scanf(
"%d"
,&
id
);
scanf(
"%d"
,&
type
);
switch(
type
){
case
0
:{
int
ch;
int
unk;
scanf(
"%d%d"
,&ch,&unk);
printf(
"\\%c"
,ch);
break
;
}
case
1
:{
printf(
"("
);
break
;
}
case
2
:{
int
ch;
scanf(
"%d"
,&ch);
printf(
"%c)"
,ch);
}
}
int
zero;
scanf(
"%d"
,&zero);
if
(zero !
=
0
){
break
;
}
}
}
f
=
open
(
"s.txt"
)
text
=
f.read()
f.close()
count
=
0
for
i
in
range
(
len
(text)):
if
(text[i]
=
=
'i'
):
count
+
=
1
else
:
if
(count>
0
):
print
(count,end
=
' '
)
if
(text[i]
=
=
'z'
):
print
()
count
=
0
print
(count)
f
=
open
(
"s.txt"
)
text
=
f.read()
f.close()
[注意]传递专业知识、拓宽行业人脉——看雪讲师团队等你加入!
赞赏记录
参与人
雪币
留言
时间
東陽不列山
为你点赞!
13小时前
一路南寻
为你点赞!
2024-11-2 01:17
shinratensei
感谢你的贡献,论坛因你而更加精彩!
2024-6-29 01:59
伟叔叔
为你点赞~
2023-3-18 05:11
一笑人间万事
为你点赞~
2022-7-28 00:00
赞赏
他的文章
看原图
赞赏
雪币:
留言: