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