Programming 板


LINE

※ 引述《gecer (gecer)》之铭言: : 标题: Re: [讨论] 排列组合的演算法解题 : 时间: Sun Aug 1 21:45:46 2021 : : 题目如下 : https://ibb.co/kSGwmyk : 用左边的6个正方形(1~6)pattern将右边的grid(20x10)填满 每一次填入至少含一个 : pattern的正方形(如N.4,只填5) grid不可重复填 要画出所有排列组合并求最小填入 : 次数 初步考虑每个grid有可能被pattern的(1~6)正方形填入 估计大约<6^200种组合 : 看到这个问题觉得有趣想了一下,我的想法如下: 首先复述一下问题: a. 物件一:带有6种pattern的矩形,数字1~6代表6种pattern,0代表空白 102 000 304 000 506 b. 物件二:20x10的table,最左上角为(0, 0) 00000000000000000000 00000000000000000000 00000000000000000000 00000000000000000000 00000000000000000000 00000000000000000000 00000000000000000000 00000000000000000000 00000000000000000000 00000000000000000000 c. 使用物件一的矩形填满物件二的table d. 物件一可超过物件二边界,但必须至少一个pattern在边界内 e. 放置物件一矩形时,不可覆盖到其他pattern,即填入1~6时,只能在0的位置填入 再来是分析填入方法: i. 由左填至右,由上填至下,每次选择一个pattern填入该格,将整个物件一矩形填入。 如果该格已填,则跳过填下一格。 ii. 是否重复? 对於中间任意格子(x, y) 填入2 = (x-2, y)填入1 填入3 = (x, y-2)填入1 填入4 = (x-2, y-2)填入1 填入5 = (x, y-4)填入1 填入6 = (x-2, y-4)填入1 因此,中间任意格子只需要考虑填入1; 又根据问题c.项,必须填满整个table,因此如果该格是空白,一定是填1 开头部分需特殊处理,参考v. iii. 是否会覆盖到已填入pattern? 根据i.和i.i.所述填法,当(x, y)为0,填入1後,会影响的位置为 (x+2, y), (x, y+2), (x+2, y+2), (x, y+4), (x+2, y+4) 当(x+2, y-2)填入1时,(x+2, y)为3,(x+2, y+2)为5,因此可能出现冲突。 一旦出现冲突,代表无法填入1,即(x, y)无填入任何值,违反问题c.项 => 尝试其他组合 iv. 是否会多算? 否,每格可能为1~6,其pattern分别是:1来自该格,2~6来自前面已填入的格子。 v. 是否会少算? 开头直接填1会少算到填入2~6的可能。 以(0, 0)为例: 如果要填入2,则必须在(-2, 0)填入1 如果要填入3,则必须在(0, -2)填入1 ... 所以从(-2, -4)开始填,可填1或不填,意即(0, 0)为6或其他。 当traverse到(0, 0)时,1~6所有可能都跑过,其他格同理。 结论; 一、在物件二开头之前加入特殊区域,从(-2, -4)开始填表,如下图所示: ********************** ********************** ********************** ********************** **00000000000000000000 **00000000000000000000 **00000000000000000000 **00000000000000000000 **00000000000000000000 **00000000000000000000 **00000000000000000000 **00000000000000000000 **00000000000000000000 **00000000000000000000 二、由左至右,由上至下填表,'*'区域可填1或者不填,'0'区域必填1 三、如遇到已填pattern的格子,跳过该格 四、如遇到冲突,返回尝试其他组合 五、统计所有排列组合和填表次数 运用上面一到五,应该就可以找到所有排列组合,至多'*'数平方 (填或不填) ∴ total <= 2^108 另外补上个recursive的pseudo code long fill_all(x, y, cnt) { if (x >= TABLE_WIDTH || y >= TABLE_HEIGHT) { print_table(); min_cnt = MIN(min_cnt, cnt); return 1; } if ((x, y) is in star area) { n1 = fill_all(next_x, next_y, cnt) if (try_fill(x, y)) { n2 = fill_all(next_x, next_y, cnt+1); clear(x, y); return n1 + n2; } else { return n1; } } else { if (try_fill(x, y)) { return fill_all(next_x, next_y, cnt+1); } else { return 0; } } } total = fill_all(-2, -4, 0) 以上是我的idea,如果逻辑上有错误,或者有多算或少算,再麻烦各位大大指正。 --



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 119.14.65.100 (台湾)
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/Programming/M.1628343343.A.7FA.html
1F:→ gecer: "*"可以到(22,-4)220.143.155.118 08/09 16:20
2F:→ gecer: (20,0)填入pattern中 "1" 的情况220.143.155.118 08/09 16:22
3F:→ gecer: sorry 看错 结论1 的table有包含上述情况了220.143.155.118 08/09 16:31
4F:→ gecer: 不过排列组合2^108指数很大 不晓得用多核220.143.155.118 08/09 16:34
5F:→ gecer: or GPU有没有机会在一定时间内算完220.143.155.118 08/09 16:34







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:iOS站内搜寻

TOP