Re: [問題] 求救!期中考第二三題(2000p)

作者: FakeGPS (一次就上手)   2018-04-22 20:30:46
※ 引述《kevinc0227 (icedragon)》之銘言:
: 但是第二題開始就有點不知該如何下手,目前的想法如下:
: 1.使用第一題的程式讀檔,dict格式。
: 2.列出所有點的TM2座標,list格式。
: 3.接下來想要將每個點的(x,y)座標減去所求點的座標,求得與所求點距離小於1.5(根號2)的點。
: 4.開一個空dict(list?),將範圍內的點的人口數放入。
: 5.最後比較哪一個所求點的人口數最多。
: 目前實在不知道3.4.5該如何以程式寫出。
: (圖二)目前進度:http://i.imgur.com/I5e2Wwm.jpg
: (附二)說明影片:http://bit.ly/2HjeqWl
: (附二)影片是一開始用來思考該如何決定賣場座標的思考方式,雖然題目說明服務範圍是正方形,以方形斜邊一半為半徑的圓,不會影響賣場座標,或許比較好思考,但之後該如何決定正方形的角度就不曉得了。
: 目前的想法如上,也不太確定這樣選取範圍的方式是否正確,實在焦頭爛額,感謝各位願意協助的版友。
我也是新手 來討論一下
題目是沒有寫得很清楚
不過我猜你們誤解老師的用意了
你們想的方向算是進階版
如果你們基礎版ok了再進階吧
題目既然給的是3x3方塊
可見他沒有要你們搞得那麼複雜
否則為什麼不是用直徑3的圓形範圍呢
圓形範圍不是比較直觀嗎
如果是3x3方塊下去擺放(不旋轉)
那其實問題簡化很多
也比較符合你們的程度
有2個做法:
第一個直接暴力地毯式搜索
在地圖上改變xy座標去滑動
被包進3x3之中的就累計人口數
然後你會得到你要的
第二個方法會非常簡單
你把每個行政里中心點依序放在3x3方塊的四個頂點
然後去看包到多少人口
如行政里1中心點為x,y
你就看這四個範圍
(x+3, y+3) (x+3, y-3) (x-3, y+3) (x-3, y-3)
共包到多少人口
依序把所有所有里跑過一遍
會有四個里放在頂點 得到最大人口數
這四個里就是解
然後你就會歸納出
3x3的中心可以擺放在
x = 最左邊的里x+1.5 ~ 最右邊的里x-1.5
y = 最上面的里y-1.5 ~ 最下面的里y+1.5
可以包到最多人
如果有誤歡迎指教啊
作者: FakeGPS (一次就上手)   2018-04-22 20:36:00
補充 這四個里 也有可能重複 變成三個里 二個里之類的
作者: kevinc0227 (icedragon)   2018-04-22 20:44:00
真的謝謝大大肯回我們 我們趕緊寫寫看
作者: FakeGPS (一次就上手)   2018-04-22 20:47:00
我覺得老師的用意應該是要你們這樣做 不可能才初學者就搞死你們 整個邏輯大約是這樣 我怕我表達不清楚 加油注意每個里有四個擺放方式喔 因為3x3有四個頂點總之最後你的解會是一個方型區域 只要賣場中心在其中即可這個方型區域的四個端點 跟你找到的那四個里有關
作者: plih (黑寶追喵咪)   2018-04-22 22:28:00
作業自己寫
作者: dx7880880212 (雨後彩虹)   2018-04-22 22:32:00
http://i.imgur.com/5DjGQQU.jpg抱歉打擾,感覺是這樣先一個點當中心,再加入其他範圍內的點,可是這樣出來的結果好像不太對@a
作者: FakeGPS (一次就上手)   2018-04-22 22:46:00
你的code很漂亮 可能我表達不夠清楚<要改用<= 然後不是把pop_1~4加總 而是比大小每次迭代都檢查 是否有更大的pop_1 pop_2 pop_3 pop_4若有 把那個里記起來 最後會得到pop_1~4都等於某個最大值我想了一下 最後的那個方形區塊解 應該會由某二個里決定
作者: dx7880880212 (雨後彩虹)   2018-04-22 23:00:00
抱歉我在釐清一下,請問是分別比較pop1234,有更大
作者: FakeGPS (一次就上手)   2018-04-22 23:00:00
所以應該是pop_1~4之中的某2個 最後會得到最大值
作者: FakeGPS (一次就上手)   2018-04-22 23:02:00
嗯嗯對 有更大的pop1就更新 pop2更新...
作者: dx7880880212 (雨後彩虹)   2018-04-22 23:02:00
*再
作者: dx7880880212 (雨後彩虹)   2018-04-22 23:06:00
好的我再試試看,最後解是指以兩個裡的中心為中心的正方形是嗎?
作者: FakeGPS (一次就上手)   2018-04-22 23:08:00
不一定是正方形唷 會是方形就對了
作者: dx7880880212 (雨後彩虹)   2018-04-22 23:10:00
所以是以兩個里為頂點的矩形囉?
作者: FakeGPS (一次就上手)   2018-04-22 23:11:00
那兩個里會是對角的兩個端點 然後方形區域你就會了
作者: dx7880880212 (雨後彩虹)   2018-04-22 23:41:00
http://i.imgur.com/AvF1iea.jpg這樣跑出來的數字是984517,01120801,9485170,1120801修正一下,上面的pop2有打錯,這樣跑出來的pop2是1120801我再想想看要怎麼推回去求點座標@@,謝謝!不過以台北市1萬人口/平方公里來說,這樣人好像太多了,我再研究一下@@
作者: FakeGPS (一次就上手)   2018-04-22 23:49:00
等等唷 你快成功了但是還是有一個錯誤想一下你的pop1 pop1_N pop2 pop2_N... 各代表什麼在換一個里當端點時 是否有東西該歸零先睡了 記得最後還有"1.5"要考慮 不要錯在終點前了
作者: dx7880880212 (雨後彩虹)   2018-04-23 09:19:00
http://i.imgur.com/MbYiDsy.jpg感覺這樣的寫法沒有表達大pop取代小pop,昨天想了半天也還不太知道怎麼改@@,我們晚上繼續,白天還有課Orz
作者: FakeGPS (一次就上手)   2018-04-23 09:41:00
難的部分都解決了 簡單的怎麼會想不出來呢 先放鬆冷靜一下再回來看 還有之前版本的 += 很美啊
作者: dx7880880212 (雨後彩虹)   2018-04-24 01:27:00
https://imgur.com/a/RrwM5qA目前的解法是長這樣,結果後來發現原本數字會到80萬上下跟一開始使用座標形式表示x,y有關@a,標示在台北市長那樣,還算合理了,感謝,繼續努力下一題Orz
作者: FakeGPS (一次就上手)   2018-04-24 09:20:00
gj 後半段可以更簡潔 不過沒關係 code沒有最好只有更好之後你們有空的話可以再檢討看看

Links booklink

Contact Us: admin [ a t ] ucptt.com