[GUET-CTF2019]re

from z3 import *
# Create a Z3 solver
solver = Solver()

# Create an array of integer variables to represent the elements of a1
a1 = [Int(f'a1[{i}]') for i in range(32)]

print(a1)

# Define the constraints based on the C code
constraints = [
    1629056 * a1[0] == 166163712,
    6771600 * a1[1] == 731332800,
    3682944 * a1[2] == 357245568,
    10431000 * a1[3] == 1074393000,
    3977328 * a1[4] == 489211344,
    5138336 * a1[5] == 518971936,
    7532250 * a1[7] == 406741500,
    5551632 * a1[8] == 294236496,
    3409728 * a1[9] == 177305856,
    13013670 * a1[10] == 650683500,
    6088797 * a1[11] == 298351053,
    7884663 * a1[12] == 386348487,
    8944053 * a1[13] == 438258597,
    5198490 * a1[14] == 249527520,
    4544518 * a1[15] == 445362764,
    3645600 * a1[17] == 174988800,
    10115280 * a1[16] == 981182160,
    9667504 * a1[18] == 493042704,
    5364450 * a1[19] == 257493600,
    13464540 * a1[20] == 767478780,
    5488432 * a1[21] == 312840624,
    14479500 * a1[22] == 1404511500,
    6451830 * a1[23] == 316139670,
    6252576 * a1[24] == 619005024,
    7763364 * a1[25] == 372641472,
    7327320 * a1[26] == 373693320,
    8741520 * a1[27] == 498266640,
    8871876 * a1[28] == 452465676,
    4086720 * a1[29] == 208422720,
    9374400 * a1[30] == 515592000,
    5759124 * a1[31] == 719890500
]

# Add the constraints to the solver
solver.add(constraints)

# Check if there is a solution
if solver.check() == sat:
    model = solver.model()
    # Get the values of a1 that satisfy the constraints
    #solution = [model[a1[i]].as_long() for i in range(32)]
    print("Solution for a1:", model)
    for i in range(32):
        print(f"a1[{i}] = {model[a1[i]]}")

else:
    print("No solution found.")

a1 = [0]*32
a1[0] = 102
a1[1] = 108
a1[2] = 97
a1[3] = 103
a1[4] = 123
a1[5] = 101
a1[6] = 49 #出题人没给,出题人傻逼来 
a1[7] = 54
a1[8] = 53
a1[9] = 52
a1[10] = 50
a1[11] = 49
a1[12] = 49
a1[13] = 49
a1[14] = 48
a1[15] = 98
a1[16] = 97
a1[17] = 48
a1[18] = 51
a1[19] = 48
a1[20] = 57
a1[21] = 57
a1[22] = 97
a1[23] = 49
a1[24] = 99
a1[25] = 48
a1[26] = 51
a1[27] = 57
a1[28] = 51
a1[29] = 51
a1[30] = 55
a1[31] = 125

result = ""
for x in range(32):
    #print(type(a1[x]))
    result += chr(a1[x])

print(result)




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CTFd是一个用于举办和参加CTF(Capture The Flag)安全竞赛的平台。根据引用\[1\]和引用\[2\]的内容,你可以按照以下步骤在Ubuntu上搭建CTFd平台: 1. 首先,确保你已经安装了虚拟机并配置好了Ubuntu系统。具体的安装和配置步骤可以参考相关的教程。 2. 配置阿里云镜像下载源文件。这可以加快软件包的下载速度。你可以按照引用\[1\]中的指导进行配置。 3. 进入CTFd目录。在终端中使用cd命令进入CTFd的目录。 4. 使用gunicorn工具配置CTFd。根据引用\[2\]和引用\[3\]的内容,你可以使用以下命令配置gunicorn工具: ``` gunicorn --bind 0.0.0.0:8000 -w 5 "CTFd:create_app()" ``` 5. 如果你希望在重启电脑后再次运行CTFd平台,确保以root权限运行。在Ubuntu终端中使用sudo命令运行上述命令。 这样,你就可以在Ubuntu上成功搭建CTFd平台了。请注意,这只是一个简单的搭建过程,具体的配置和使用方法可能会有所不同,你可以参考相关的文档和教程进行更详细的了解和操作。 #### 引用[.reference_title] - *1* *2* *3* [基于Ubuntu搭建CTFd平台(全网最全)](https://blog.csdn.net/qq_25953411/article/details/127489944)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值