Re: [問題] 數獨的出題方法
※ 引述《bobbob (bobbob)》之銘言:
: 想請問ㄧ下...我們平常都是做別人出好題目的數讀...
: 那如果我們自己想出題目的話...請問有啥需要注意的嗎??
: 首先應該是先想好解答...然後再逐步將一些解答拿掉以變成題目吧...
: 那如何得知拿掉哪些格子不會影響解答又可以將最後的答案解出來呢??
: 不知道我這樣敘訴大家看的懂嗎??
我之前寫程式是用跟你相反的作法
先隨機填20個格子 (因為有人研究一個題目至少要17個,有沒有更少的不知道)
(之間當然要確定這20個填完之後盤面還是合法的)
在第21個開始也是隨機填 , 每填完一格檢查有沒有多重解
檢查的方法就是用暴搜+刪去法
因為暴搜可以知道題目有沒有解
用刪去法可能會有唯一解或卡住(no sol)
先暴搜可過以後再丟給刪去法解
若可解題目就會有唯一解了
遇到無解或多重解則有各自的作法不贅述
之前跟同學討論 這樣做可能會有點慢
但"填"比"拔"好的地方是可以創造新的題目
而且如果只是9*9不會太慢 要到16*16才真的需要想別的方法
--
http://blog.yam.com/akqj10
我的 地獄X生活X喜樂
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 220.133.54.137
→
04/11 21:08, , 1F
04/11 21:08, 1F
推
04/11 22:04, , 2F
04/11 22:04, 2F
→
04/11 22:05, , 3F
04/11 22:05, 3F
推
04/11 22:38, , 4F
04/11 22:38, 4F
推
04/11 22:58, , 5F
04/11 22:58, 5F
→
04/12 03:02, , 6F
04/12 03:02, 6F
推
04/12 09:19, , 7F
04/12 09:19, 7F
討論串 (同標題文章)