


全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
【问题描述】在一个划分成网格的操场上,n个士兵散乱地站在网格点上。网格点用整数坐标(x,y)表示。士兵们可以沿网格边往上、下、左、右移动一步,但在同一时刻任一网格点上只能有一名士兵。按照军官的命令,士兵们要整齐地列成一个水平队列,即排列成(x,y),(x+1,y),(x+n-1,y)。如何选择x和y的值才能使士兵们以最少的总移动步数排成一行。编程计算使所有士兵排成一行需要的最少移动步数。【输入格式】第1行是士兵数n,1n10000。接下来n行是士兵的初始位置,每行有2个整数x和y,-10000x,y10000。【输出格式】一个数据,即士兵排成一行需要的最少移动步数。【输入样例】sol.in51 22 21 33 -23 3【输出样例】sol.out8分析:一 士兵有多种移动方式通过适当的移动顺序和移动路线可以使得同一时刻不会有两名士兵站在同一点二 题目要求最佳移动方式(即求移动的最少步数)题目要求转化为求士兵站立的“最终位置”,即如何取“最终位置”使得士兵移动的步数最少(最优)Y轴方向上的考虑设目标坐标为M,即n个士兵最终需要移动到的Y轴的坐标值为Mn个士兵的Y轴坐标分别为:Y0,Y1,Y2 Yn-1则最优步数S=|Y0-M|+|Y1-M|+|Y2-M|+ +|Yn-1-M|结论:M取中间点的值使得S为最少(最优)证明:从最上和最下的两个士兵开始递推最优位置最优位置归结到最后,处于中间位置的士兵的Y轴坐标值就是“最终位置”的Y轴坐标可能有两种情况士兵总数为双数情况:取中间两点间的任意一个位置士兵总数为单数情况:取中间点的所在位置解决办法:对所有的Y轴坐标进行排序(O(nlogn)或者进行线性时间选择(O(n)然后取“中间”点的Y轴坐标值作为最佳位置M的值最后通过公式求出Y轴方向上移动的最优步数X轴方向上的考虑首先需要对所有士兵的X轴坐标值进行排序然后,按从左至右的顺序依次移动到每个士兵所对应的“最终位置”(最优),所移动的步数总和就是X轴方向上需要移动的步数例,最左的士兵移动到“最终位置”的最左那位,第二个士兵移动到“最终位置”的第二位则总的步数为:士兵一移动步数+士兵二移动步数+ +士兵n移动步数如何确定X轴方向上的最佳的“最终位置”?共n个士兵他们相应的X轴坐标为:X0,X1,X2 Xn-1设,士兵需要移动到的“最终位置”的X轴坐标值为:k,k+1,k+2 k+(n-1)则所求最优步数S=|X0-k|+|X1- (k+1) |+|X2-(k+2)|+ +|Xn-1-(k+(n-1)|经过变形S=|X0-k|+|(X1-1)-k|+|(X2-2)-k|+ +|(Xn-1-(n-1)-k|注意到公式的形式与Y轴方向上的考虑一样,同样是n个已知数分别减去一个待定数后取绝对值,然后求和因此还是采用取中位数的办法求得k值,最后算出最优解。参考程序:type arr=array-10001.10001of longint;var i,j,k,l,n,m,num:longint; f:array-10001.10001of boolean; a,b,c:arr;procedure ok(l,r:longint);var i,j,x,y:longint;begin i:=l;j:=r;x:=a(l+r) div 2; repeat while aix do i:=i+1; while xaj do j:=j-1; if ij; if lj then ok(l,j); if ir then ok(i,r);end;procedure ok1(l,r:longint);var i,j,x,y:longint;begin i:=l;j:=r;x:=b(l+r) div 2; repeat while bix do i:=i+1; while xbj do j:=j-1; if ij; if lj then ok1(l,j); if ir then ok1(i,r);end;beginassign(input,sol.in);assign(output,sol.out);reset(input);rewrite(output);readln(n);for i:=1 to n doreadln(ai,bi);ok(1,n);ok1(1,n);for i:=1 to n doai:=ai-i+1;ok(1,n);l:=0;k:=a(1+n) div 2;for i:=1 to n dol:=l+abs(ai-k
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- z-c-s-y-w课件教学课件
- 生产线中断应急预案
- 粉尘烟雾污染应急预案
- 2025年医学三基考试题库及参考答案
- 2025年监理工程师《水利工程(全科)》考试题库(附答案)
- 2025年法制教育测试题及答案
- 乡镇财政监管培训课件
- 城市交通拥堵治理技术创新可行性分析报告2025
- 乡镇统计法培训课件
- 素描基础试题及答案
- 会诊记录本完整版本
- 七年级上册全部古诗词【注释与主旨】(最完整)
- 《供应商开发》课件
- 侵权赔偿索赔授权委托书法院
- 《汉译英理论与实践》课件
- 国有企业招标采购相关法律法规与国有企业采购操作规范
- 部编版四年级语文下册课件:4《乡下人家》第一课时
- 班级文化建设一等奖-完整版课件
- 2023年国际心肺复苏(CPR)与心血管急救(ECC)指南
- 财务公司有价证券投资管理办法
- 鼻内翻性乳头状瘤
评论
0/150
提交评论