NOIP2008普及组(复赛)

上传人:工**** 文档编号:397354550 上传时间:2022-09-21 格式:DOC 页数:41 大小:993KB
返回 下载 相关 举报
NOIP2008普及组(复赛)_第1页
第1页 / 共41页
NOIP2008普及组(复赛)_第2页
第2页 / 共41页
NOIP2008普及组(复赛)_第3页
第3页 / 共41页
NOIP2008普及组(复赛)_第4页
第4页 / 共41页
NOIP2008普及组(复赛)_第5页
第5页 / 共41页
点击查看更多>>
资源描述

《NOIP2008普及组(复赛)》由会员分享,可在线阅读,更多相关《NOIP2008普及组(复赛)(41页珍藏版)》请在金锄头文库上搜索。

1、Four short words sum up what has lifted most successful individuals above the crowd: a little bit more.-author-dateNOIP2008普及组(复赛)NOIP2008普及组(复赛)全国信息学奥林匹克联赛(NOIP2008)复赛普及组一.题目概览中文题目名称ISBN号码排座椅传球游戏立体图英文题目名称isbnseatballdrawing可执行文件名isbnseatballdrawing输入文件名isbn.inseat.inball.indrawing.in输出文件名isbn.outse

2、at.outball.outdrawing.out每个测试点时限1秒1秒1秒1秒测试点数目10101010每个测试点分值10101010比较方式全文比较全文比较全文比较全文比较题目类型传统传统传统传统二.提交源程序文件名对于pascal语言isbn.passeat.pasball.pasdrawing.pas对于C语言isbn.cseat.cball.cdrawing.c对于C+语言isbn.cppseat.cppball.cppdrawing.cpp三.编译命令(不包含任何优化开关)对于pascal语言fpc isbn.pasfpc seat.pasfpc ball.pasfpc drawi

3、ng.pas对于C语言gcc o isbnisbn.cgcc o seatseat.cgcc o ballball.cgcc o drawingdrawing.c对于C+语言g+ o isbnisbn.cppg+ o seatseat.cppg+ o ballball.cppg+ o drawingdrawing.cpp四.运行内存限制运行内存上限50M50M50M50M注意事项:1、文件名(程序名和输入输出文件名)必须使用小写。2、C/C+中函数main()的返回值类型必须是int,程序正常结束时的返回值必须是0。3、全国统一评测时采用的机器配置为:CPU 1.9GHz, 内存512M, 上

4、述时限以此配置为准。各省在自测时可根据具体配置调整时限。1.ISBN号码 (isbn.pas/c/cpp)【问题描述】每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字、1位识别码和3位分隔符,其规定格式如“x-xxx-xxxxx-x”,其中符号“-”是分隔符(键盘上的减号),最后一位是识别码,例如0-670-82162-4就是一个标准的ISBN码。ISBN码的首位数字表示书籍的出版语言,例如0代表英语;第一个分隔符“-”之后的三位数字代表出版社,例如670代表维京出版社;第二个分隔之后的五位数字代表该书在出版社的编号;最后一位为识别码。识别码的计算方法如下:首位数字乘以

5、1加上次位数字乘以2以此类推,用所得的结果mod 11,所得的余数即为识别码,如果余数为10,则识别码为大写字母X。例如ISBN号码0-670-82162-4中的识别码4是这样得到的:对067082162这9个数字,从左至右,分别乘以1,2,9,再求和,即01+62+29=158,然后取158 mod 11的结果4作为识别码。你的任务是编写程序判断输入的ISBN号码中识别码是否正确,如果正确,则仅输出“Right”;如果错误,则输出你认为是正确的ISBN号码。【输入】输入文件isbn.in只有一行,是一个字符序列,表示一本书的ISBN号码(保证输入符合ISBN号码的格式要求)。【输出】输出文件

6、isbn.out共一行,假如输入的ISBN号码的识别码正确,那么输出“Right”,否则,按照规定的格式,输出正确的ISBN号码(包括分隔符“-”)。【输入输出样例1】isbn.inisbn.out0-670-82162-4Right【输入输出样例2】isbn.inisbn.out0-670-82162-00-670-82162-42.排座椅 (seat.pas/c/cpp)【问题描述】 上课的时候总有一些同学和前后左右的人交头接耳,这是令小学班主任十分头疼的一件事情。不过,班主任小雪发现了一些有趣的现象,当同学们的座次确定下来之后,只有有限的D对同学上课时会交头接耳。同学们在教室中坐成了M行

7、N列,坐在第i行第j列的同学的位置是(i,j),为了方便同学们进出,在教室中设置了K条横向的通道,L条纵向的通道。于是,聪明的小雪想到了一个办法,或许可以减少上课时学生交头接耳的问题:她打算重新摆放桌椅,改变同学们桌椅间通道的位置,因为如果一条通道隔开了两个会交头接耳的同学,那么他们就不会交头接耳了。请你帮忙给小雪编写一个程序,给出最好的通道划分方案。在该方案下,上课时交头接耳的学生对数最少。【输入】输入文件seat.in的第一行,有5各用空格隔开的整数,分别是M,N,K,L,D(2=N,M=1000,0=KM,0=LN,D=2000)。接下来D行,每行有4个用空格隔开的整数,第i行的4个整数

8、Xi,Yi,Pi,Qi,表示坐在位置(Xi,Yi)与(Pi,Qi)的两个同学会交头接耳(输入保证他们前后相邻或者左右相邻)。输入数据保证最优方案的唯一性。【输出】输出文件seat.out共两行。第一行包含K个整数,a1a2aK,表示第a1行和a1+1行之间、第a2行和第a2+1行之间、第aK行和第aK+1行之间要开辟通道,其中ai ai+1,每两个整数之间用空格隔开(行尾没有空格)。第二行包含L个整数,b1b2bk,表示第b1列和b1+1列之间、第b2列和第b2+1列之间、第bL列和第bL+1列之间要开辟通道,其中bi2-3-1和1-3-2-1,共2种。【输入】输入文件ball.in共一行,有

9、两个用空格隔开的整数n,m(3=n=30,1=m=30)。【输出】输出文件ball.out共一行,有一个整数,表示符合题意的方法数。【输入输出样例】ball.inball.out3 32【限制】40%的数据满足:3=n=30,1=m=20100%的数据满足:3=n=30,1=m=30直接dp,似乎说递推更确切点。f(i,k)表示经过k次传到编号为i的人手中的方案数。那么可以推出下面的方程:f(i,k)=f(i-1,k-1)+f(i+1,k-1) (i=1或n时,需单独处理)边界条件:f(1,0)=1;结果在f(1,m)中4.立体图 (drawing.pas/c/cpp)【问题描述】小渊是个聪明

10、的孩子,他经常会给周围的小朋友们讲些自己认为有趣的内容。最近,他准备给小朋友们讲解立体图,请你帮他画出立体图。小渊有一块面积为m*n的矩形区域,上面有m*n个边长为1的格子,每个格子上堆了一些同样大小的积木(积木的长宽高都是1),小渊想请你打印出这些格子的立体图。我们定义每个积木为如下格式,并且不会做任何翻转旋转,只会严格以这一种形式摆放: +-+ / /| 高+-+ | | +| |/ 宽+-+ 长每个顶点用1个加号+表示,长用3个”-“表示,宽用1个”/”表示,高用两个”|”表示。字符+ -/ |的ASCII码分别为43,45,47,124。字符.(ASCII码46)需要作为背景输出,即立

11、体图里的空白部分需要用.代替。立体图的画法如下面的规则:若两块积木左右相邻,图示为:.+-+-+./ / /|+-+-+ | | | +| | |/.+-+-+.若两块积木上下相邻,图示为:.+-+./ /|+-+ | | +| |/|+-+ | | +| |/.+-+.若两块积木前后相邻,图示为:.+-+/ /|.+-+ |./ /| +-+ |/.| | +.| |/+-+.立体图中,定义位于第(m,1)的格子(即第m行第1列的格子)上面自底向上的第一块积木(即最下面的一块积木)的左下角顶点为整张图最左下角的点。【输入】输入文件drawing.in第一行有用空格隔开的两个整数m和n,表示有m*n个格子(1=m,n=50)。接下来的m行,是一个m*n的矩阵,每行有n个用空格隔开的整数,其中第i行第j列上的整数表示第i行第j列的格子上摞有多少个积木(1=每个格子上的积木数=100)。【输出】输出文件drawing.out中包含题目要求的立体图,是一个K行L列的字符矩阵,其中K和L表示最少需要K行L列才能按规定输出立体图。【输入输出样例】drawing.in

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号