UPX壳,手脱后打不开,可能是在windows10脱壳的缘故吧。放在XP虚拟机上手脱可能会好,但是提示缺少dll。无奈,智能用工具了。

用的这个,感觉蛮好用的。

先打开程序。随便输入一个数,提示error

IDA中找到相应字符串。

F5反编译

可以看到,在while循环里面,限制我们输入的字符串必须是L或者R。当时我就输入了19个L,结果提示了error。按照代码的逻辑来看,讲道理是不可能出现这种情况的。

后来想可能是这个sub_41114F函数有问题,但是当我在IDA中查看时,出现了下面的情况。

这个问题不清楚,于是改用OD。进入这个函数查看。

首先调用了call 004110A5,这个函数结束后,后面的汇编代码会发生改变。如下图。

进入IDA来看看call 004110A5函数,如下图

这几个Virtual函数查了百度,并不是太明白。不过结合OD的调试,和IDA反编译的结果,可以推测出具体作用是:从某个地址开始,对每个字节进行异或4运算。一共有0x40个字节被改变。

这个推测可以在OD中得到验证。图中框出来的就是被改变了的,一共0x40个字节。这里也许就可以解释为何在IDA中反编译失败了,因为没有经过这个函数动态变化后的代码是错误的,因此无法反编译导致错误。

分析上图汇编代码,容易得到,对输入的字符串中偶数位的进行异或,奇数位不变。

然后输入LHLHLHLHLHLHLHLHLHL,异或后即十九个L(这里我没注意,后面写脚本的时候以为是LR交替的,导致浪费了很多时间)。放进去跑一跑试试。

提示得到了303755。这里的话,结合题目mountain climbing想一想,还有就是L和R,一个左一个右。推测应该是输入LR组合,让这个数达到最大值。

回到IDA查看。

由rand函数获得随机值,

然后放入423D78中。最后输出的值就是423D78了。写脚本跑出来就行了。以IDA反编译的源码为基础,稍微改一改就ok了。

#include <stdlib.h>
#include <iostream>
using namespace std;
int main()
{ int i,j;
int Sum=;
int v7=;
int v5=;
int v3=;
string flag;
srand(0xc); //rand函数包含在stdlib头文件中
int Array[];
for ( i = ; i <= ; ++i )
{
for (j = ; j <= i; ++j )
{
Array[ * i + j] = rand() % ;
}
}
Sum+=Array[];
while(v3<) //判断哪个大,哪个大就加哪个
{
if(Array[ * (v7+) + v5]>Array[ * (v7+) + v5 + ])
{
flag+="L";
Sum += Array[ * ++v7 + v5];
}
else
{
flag+="R";
Sum += Array[ * ++v7 + ++v5];
}
v3++;
}
for(i=;i<flag.length();i++) if(i%==) flag[i]=flag[i]^; //异或处理
cout << flag;
return ;
}

BUGKU (Mountain climbing)的更多相关文章

  1. P1561 [USACO12JAN]爬山Mountain Climbing

    P1561 [USACO12JAN]爬山Mountain Climbing 题目描述 Farmer John has discovered that his cows produce higher q ...

  2. [USACO 12JAN]Mountain Climbing

    Description Farmer John has discovered that his cows produce higher quality milk when they are subje ...

  3. [USACO12JAN]爬山Mountain Climbing

    题目描述 Farmer John has discovered that his cows produce higher quality milk when they are subject to s ...

  4. 洛谷—— P1561 [USACO12JAN]爬山Mountain Climbing

    https://daniu.luogu.org/problemnew/show/P1561 题目描述 Farmer John has discovered that his cows produce ...

  5. 洛谷 P1561 [USACO12JAN]爬山Mountain Climbing

    传送门 题目大意: n头牛,上山时间为u(i),下山为d(i). 要求每一时刻最多只有一头牛上山,一头牛下山. 问每头牛都上下山后花费最少时间. 题解:贪心 推了推样例,发现上山时间一定,那找个下山最 ...

  6. 洛谷【P1561】[USACO12JAN]爬山Mountain Climbing

    我对\(Jhonson\)算法的理解:https://www.cnblogs.com/AKMer/p/9863620.html 题目传送门:https://www.luogu.org/problemn ...

  7. 【伪随机数】【搜索】【RE】【bugku】mountainclimbing WriteUp

    Mountain Climbing WP 拿到题首先熟练地查个壳再用各种脱壳工具脱个壳. 脱壳之后熟练地双击感受一下出题者的恶意: 根据字面意思得知,是要根据一系列的操作来得到收益最大值,于是用ida ...

  8. BUGKU-逆向(reverse)-writeup

    目录 入门逆向 Easy_vb Easy_Re 游戏过关 Timer(阿里CTF) 逆向入门 love LoopAndLoop(阿里CTF) easy-100(LCTF) SafeBox(NJCTF) ...

  9. How to do Mathematics

    著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处.作者:匿名用户链接:http://www.zhihu.com/question/30087053/answer/47815698来源 ...

随机推荐

  1. jQuery 实现手风琴菜单

    main.js $(function(){ var tmp = null, $title = $('.title'), $con = $('.title > ul'); $title.click ...

  2. NOI2018 你的名字——SAM+线段树合并

    题目链接在这里洛谷/LOJ 题目大意 有一个串\(S\),每次询问给你一个串\(T\),两个数\(L\)和\(R\),问你\(T\)有多少个本质不同的子串不是\(S[L,R]\)的子串 SOLUTIO ...

  3. IDEA-maven的配置

    一.下载maven的包 http://www.apache.org/ 1.在网页中打开上面的网址,进入下面的页面 2.拖动滚动条往下拉,找到maven 进入之后,点击Download 3.选择wind ...

  4. 【JAVA-算法】 截取2个字符中间的字符串

    Java Code /** 截取2个字符中间的字符串 */ private void GetMiddleString() { String str = "BB022220011BB007EB ...

  5. UVAlive 7414 Squeeze the Cylinders a,b,c三种步数 搜索+最短路

    题意:给你n个点(n<=50),然后有些点之间会有一条路,路是单向的,每个回合让你走a,b,c三种步数中的任意一种(a,b,c<=100),问你最少需要多少个回合才能保证一定能从1点到达n ...

  6. 【luoguP1196】 [NOI2002]银河英雄传说--边带权并查集 ,

    题目描述 公元五八○一年,地球居民迁至金牛座α第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展. 宇宙历七九九年,银河系的两大军事集团在巴米利恩星域爆发战争.泰山压顶 ...

  7. AGC029C - Lexicographic constraints

    记录我心路历程吧,这道小水题暴露出我很多问题. 给定 \(n\) 个字符串长度 \(a_i\) ,求字符集最小多大,才能构造出按字典序比较 \(s_1 < s_2 < \dots < ...

  8. jquery.qrcode.js生成二维码(前端生成二维码)

    官网地址:http://jeromeetienne.github.io/jquery-qrcode/ 第一步引入插件: <script type='text/javascript' src='h ...

  9. 简易的学生成绩管理系统(C++实现)

    最近浅显的学习了C++的基础知识,想来练练手,于是就用单链表写了最经典的小项目,存粹学习,所以就在控制台下写了,写的有点简陋,码了大概400多行. 下面上代码: #include <cstdli ...

  10. C#中如何去掉字"/0"

    string str = "you/0are/0sweet/0"; str = str.replace("/0","")); 备忘一下