[工学]北京大学ACM国际大学生程序设计竞赛课件2.ppt

[工学]北京大学ACM国际大学生程序设计竞赛课件2.ppt

  1. 1、本文档共38页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
[工学]北京大学ACM国际大学生程序设计竞赛课件2

问题求解与程序设计 第二讲 对局问题 李文新 2004.2 – 2004.6 内容提要 上周作业总结 放硬币问题 取火柴问题 取石子问题 - n堆 取石子问题 – 1堆 作业 – 装箱问题 1005题 弗雷德先生想在路易斯安娜州买一块地造房子。在调查中他了解到由于密西西比河的侵蚀,路易斯安娜州正在以每年50平方英里的速度变小。因为弗雷德先生希望在他的新房子里生活直至终老,所以他想知道他的房子是否会被侵蚀掉。 1005题 经过进一步研究,弗雷德发现将要被侵蚀得陆地呈半圆形。半圆是一个以(0,0)点为中心的圆的一半,半圆的直边是X轴。X轴以下的部分在水中。在第一年的开始,圆的面积是0。(半圆如下图所示)。 1005 – 问题 1005 –问题分析 1)分析问题寻求算法 因为河水呈半圆形扩散,每年扩散50平方英里,所以当给定一点的坐标时,可以用它与原点的距离作为半径,计算以此为半径的半圆的面积,在用这一面积除以50,向上取整,得到的就是要求的年数。即使用如下公式计算: 1005 – 源代码 #include?stdio.h //将输入输出的库函数包含 #include?math.h //将用到的库函数包含进来 void?main() { //程序开始 ???? float?x,y; //用来存放读入的坐标值 ?? int?year; //用于保存计算出来的年数 ???? scanf(“%f?%f”,x,y); //从键盘读入坐标值 ???? year?=?(int)ceil((x*x+y*y)*3.1415926/2/50); //套用公式计算年数 ??? printf(“第?%d年年末\n”,??year);? //将算出来的年数输出到屏幕上 } //程序结束 1006题 人生来就有三个生理周期,分别为体力、感情和智力周期,它们的周期长度为23天、28天和33天。每一个周期中有一天是高峰。在高峰这天,人会在相应的方面表现出色。例如,智力周期的高峰,人会思维敏捷,精力容易高度集中。因为三个周期的周长不同,所以通常三个周期的高峰不会落在同一天。对于每个人,我们想知道何时三个高峰落在同一天。对于每个周期,我们会给出从当前年份的第一天开始,到出现高峰的天数(不一定是第一次高峰出现的时间)。你的任务是给定一个从当年第一天开始数的天数,输出从给定时间开始(不包括给定时间)下一次三个高峰落在同一天的时间(距给定时间的天数)。例如:给定时间为10,下次出现三个高峰同天的时间是12,则输出2(注意这里不是3)。 1006题 输入 输入四个整数:p, e, i和d。 p, e, i分别表示体力、情感和智力高峰出现的时间(时间从当年的第一天开始计算)。d 是给定的时间,可能小于p, e, 或 i。 所有给定时间是非负的并且小于365, 所求的时间小于21252 。 输出 从给定时间起,下一次三个高峰同天的时间(距离给定时间的天数)。 1006题 问题分析 ? 令所求的时间为当年的第x天,则x具有如下性质: 1) 21252 = x d 2) (x-p)%23=0 3) (x-e)%28=0 4) (x-i)%33=0 1006题 一个最简单直观的做法就是枚举从d+1 到 21252 之间所有的数字,寻找第一个满足条件2)3)4)的数字,注意输出时间减去d.。 1006题 可以做的进一步改进是从d+1开始逐一枚举寻找满足条件2)的数字a,从a开始每步加23寻找满足条件2)3)的数字b,从b开始每步加23*28寻找满足条件2)3)4)的数字x。x就是我们要找的数字,输出时输出x-d。 1006题 程序设计 ? // 读入p, e, i, d // j从d+1 循环到21252, 如果 (j-p)%23==0,跳出循环 // j从上次跳出循环的值循环到21252, 如果 (j-e)%28==0,跳出循环 // j从上次跳出循环的值循环到21252, 如果 (j-i)%33==0,跳出循环 // 输出j-d 1006题 #include stdio.h #include math.h void main(){ int p,e,i,d,j,no=1; scanf(%d %d %d %d\n,p,e,i,d); while(p!=-1 e!=-1 i!=-1 d!=-1){ for(j=d+1; j=21252; j++) if ((j-p)%23 == 0) break;

文档评论(0)

qiwqpu54 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档