鱼C论坛

 找回密码
 立即注册
查看: 1036|回复: 13

[已解决]重金求方案(

[复制链接]
发表于 2023-11-20 22:22:34 | 显示全部楼层 |阅读模式
10鱼币

我最近闲着没事,整了个十阶幻方生成器:
#made with python3.10

import random

print('生成中……\n')

while True:
    x = []
    for count in range(10):
        x.append([])

    for count in range(10):
        x[0].append(random.randint(-9999999999, 1000000000))
        x[1].append(random.randint(-9999999999, 1000000000))
        x[2].append(random.randint(-9999999999, 1000000000))
        x[3].append(random.randint(-9999999999, 1000000000))
        x[4].append(random.randint(-9999999999, 1000000000))
        x[5].append(random.randint(-9999999999, 1000000000))
        x[6].append(random.randint(-9999999999, 1000000000))
        x[7].append(random.randint(-9999999999, 1000000000))
        x[8].append(random.randint(-9999999999, 1000000000))
        x[9].append(random.randint(-9999999999, 1000000000))

    a = bool(sum(x[0]) == sum(x[1]) == sum(x[2])== sum(x[3]) == sum(x[4]) \
    == sum(x[5]) == sum(x[6]) == sum(x[7])== sum(x[8]) == sum(x[9]))

    b = bool(x[0][0] + x[0][1] + x[0][2] + x[0][3] + x[0][4] + x[0][5] + x[0][6] + x[0][7] + x[0][8] + x[0][9] == \
             x[1][0] + x[1][1] + x[1][2] + x[1][3] + x[1][4] + x[1][5] + x[1][6] + x[1][7] + x[1][8] + x[1][9] == \
             x[2][0] + x[2][1] + x[2][2] + x[2][3] + x[2][4] + x[2][5] + x[2][6] + x[2][7] + x[2][8] + x[2][9] == \
             x[3][0] + x[3][1] + x[3][2] + x[3][3] + x[3][4] + x[3][5] + x[3][6] + x[3][7] + x[3][8] + x[3][9] == \
             x[4][0] + x[4][1] + x[4][2] + x[4][3] + x[4][4] + x[4][5] + x[4][6] + x[4][7] + x[4][8] + x[4][9] == \
             x[5][0] + x[5][1] + x[5][2] + x[5][3] + x[5][4] + x[5][5] + x[5][6] + x[5][7] + x[5][8] + x[5][9] == \
             x[6][0] + x[6][1] + x[6][2] + x[6][3] + x[6][4] + x[6][5] + x[6][6] + x[6][7] + x[6][8] + x[6][9] == \
             x[7][0] + x[7][1] + x[7][2] + x[7][3] + x[7][4] + x[7][5] + x[7][6] + x[7][7] + x[7][8] + x[7][9] == \
             x[8][0] + x[8][1] + x[8][2] + x[8][3] + x[8][4] + x[8][5] + x[8][6] + x[8][7] + x[8][8] + x[8][9] == \
             x[9][0] + x[9][1] + x[9][2] + x[9][3] + x[9][4] + x[9][5] + x[9][6] + x[9][7] + x[9][8] + x[9][9] )
             

    c = bool(x[0][0] + x[1][1] + x[2][2] + x[3][3] + x[4][4] + x[5][5] + x[6][6] + x[7][7] + x[8][8] + x[9][9] == \
    x[0][9] + x[1][8] + x[2][7] + x[3][6] + x[4][5] + x[5][4] + x[6][3] + x[7][2] + x[8][1] + x[9][0])

    d = bool(x[0][0] != x[0][1] != x[0][2] != x[0][3] != x[0][4] != x[0][5] != x[0][6] != x[0][7] != x[0][8] != \
             x[0][9] != x[1][0] != x[1][1] != x[1][2] != x[1][3] != x[1][4] != x[1][5] != x[1][6] != x[1][7] != \
             x[1][8] != x[1][9] != x[2][0] != x[2][1] != x[2][2] != x[2][3] != x[2][4] != x[2][5] != x[2][6] != \
             x[2][7] != x[2][8] != x[2][9] != x[3][0] != x[3][1] != x[3][2] != x[3][3] != x[3][4] != x[3][5] != \
             x[3][6] != x[3][7] != x[3][8] != x[3][9] != x[4][0] != x[4][1] != x[4][2] != x[4][3] != x[4][4] != \
             x[4][5] != x[4][6] != x[4][7] != x[4][8] != x[4][9] != x[5][0] != x[5][1] != x[5][2] != x[5][3] != \
             x[5][4] != x[5][5] != x[5][6] != x[5][7] != x[5][8] != x[5][9] != x[6][0] != x[6][1] != x[6][2] != \
             x[6][3] != x[6][4] != x[6][5] != x[6][6] != x[6][7] != x[6][8] != x[6][9] != x[7][0] != x[7][1] != \
             x[7][2] != x[7][3] != x[7][4] != x[7][5] != x[7][6] != x[7][7] != x[7][8] != x[7][9] != x[8][0] != \
             x[8][1] != x[8][2] != x[8][3] != x[8][4] != x[8][5] != x[8][6] != x[8][7] != x[8][8] != x[8][9] != \
             x[9][0] != x[9][1] != x[9][2] != x[9][3] != x[9][4] != x[9][5] != x[9][6] != x[9][7] != x[9][8] != x[9][9])

    if a == b == c == d == True :
        break

print('生成完毕!\n')
print(*x[0])
print(*x[1])
print(*x[2])
print(*x[3])
print(*x[4])
print(*x[5])
print(*x[6])
print(*x[7])
print(*x[8])
print(*x[9])


没有BUG,但是效率好低(
完全跑不动啊(
求一个好使的优化方案(
最佳答案
2023-11-20 22:22:35
利用NumPy的数组操作来计算行和、列和以及对角线和:
import random
import numpy as np

print('生成中……\n')

while True:
    x = np.random.randint(-9999999999, 1000000000, size=(10, 10))

    row_sums = x.sum(axis=1)
    col_sums = x.sum(axis=0)
    diagonal_sum1 = np.trace(x)
    diagonal_sum2 = np.trace(np.fliplr(x))

    if all(row_sums == row_sums[0]) and all(col_sums == col_sums[0]) and diagonal_sum1 == diagonal_sum2:
        break

print('生成完毕!\n')
for row in x:
    print(*row)

最佳答案

查看完整内容

利用NumPy的数组操作来计算行和、列和以及对角线和:

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-20 22:22:35 | 显示全部楼层    本楼为最佳答案   
利用NumPy的数组操作来计算行和、列和以及对角线和:
import random
import numpy as np

print('生成中……\n')

while True:
    x = np.random.randint(-9999999999, 1000000000, size=(10, 10))

    row_sums = x.sum(axis=1)
    col_sums = x.sum(axis=0)
    diagonal_sum1 = np.trace(x)
    diagonal_sum2 = np.trace(np.fliplr(x))

    if all(row_sums == row_sums[0]) and all(col_sums == col_sums[0]) and diagonal_sum1 == diagonal_sum2:
        break

print('生成完毕!\n')
for row in x:
    print(*row)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-20 23:04:56 | 显示全部楼层
你说的是哪种幻方?

Snipaste_2023-11-20_23-04-42.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-21 10:08:13 | 显示全部楼层
《random》
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-21 10:09:45 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2023-11-21 21:11:21 | 显示全部楼层

高次幻方
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2023-11-21 21:18:42 | 显示全部楼层

随机生成100个数字,检验是否符合条件,符合就输出啊?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-21 21:20:35 | 显示全部楼层
本帖最后由 tommyyu 于 2023-11-21 21:24 编辑
半灵桑 发表于 2023-11-21 21:18
随机生成100个数字,检验是否符合条件,符合就输出啊?


https://zhuanlan.zhihu.com/p/121838438
你这个程序的时间复杂度 O(m^n) 起步(n -> 幻方大小, m -> 随机范围),不超时才怪
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-21 21:25:16 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2023-11-21 22:18:46 | 显示全部楼层
tommyyu 发表于 2023-11-21 21:20
https://zhuanlan.zhihu.com/p/121838438
你这个程序的时间复杂度 O(m^n) 起步(n -> 幻方大小, m ->  ...

超时?我闲着没事搞的啊(
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-22 11:40:39 | 显示全部楼层
半灵桑 发表于 2023-11-21 22:18
超时?我闲着没事搞的啊(


*至少超过一个小时
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-22 15:05:23 | 显示全部楼层
这种问题的优化……去stack overflow问试试看
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-22 17:41:36 | 显示全部楼层
mojo?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-22 21:42:49 | 显示全部楼层


之前有人扒出来,mojo 在官方声明里面写的大意是:
对于所有的 Python3 代码,我们内置了一个 CPython 解释器,并直接用 CPython 运行。


《真·兼容 Python》
详见https://www.bilibili.com/video/B ... id_from=333.999.0.0
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-23 03:13

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表