ImageVerifierCode 换一换
格式:DOCX , 页数:17 ,大小:34.24KB ,
资源ID:12672668      下载积分:6 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-12672668.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(第十一届全国青少年信息学奥林匹克联赛初赛提PC试题与答案.docx)为本站会员(b****8)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

第十一届全国青少年信息学奥林匹克联赛初赛提PC试题与答案.docx

1、第十一届全国青少年信息学奥林匹克联赛初赛提PC试题与答案NOIP2005第十一届全国青少年信息学奥林匹克联赛初赛(提高组P&C)试题及答案 全部试题答案均要求写在答卷纸上,写在试卷纸上一律无效一、单项选择题(共10题,每题1.5分,共计15分。每题有且仅有一个正确答案.)。1. 字符串“ababacbab”和字符串“abcba”的最长公共子串是( )。A. abcba B. cba C. abc D. ab E. bcba= = a, b, c, d, e, f, C A 2. 设全集I = a, b, c, d, e, f, g, h,集合B A c, d, e,为( )。 = a, d,那

2、么集合C B A B A A. c, e B. d, e C. e D. c, d, e E. d, f3. 以下二进制数的值与十进制数23.456 的值最接近的是( )。A. 10111.0101 B. 11011.1111 C. 11011.0111 D. 10111.0111 E. 10111.11114. 完全二叉树的结点个数为4 * N + 3,则它的叶结点个数为( )。A. 2 * N B. 2 * N - 1 C. 2 * N + 1 D. 2 * N - 2 E. 2 * N + 25. 平面上有五个点A(5, 3), B(3, 5), C(2, 1), D(3, 3), E(

3、5, 1)。以这五点作为完全图G 的顶点,每两点之间的直线距离是图G 中对应边的权值。图G 的最小生成树中的所有边的权值综合为( )。A. 8 B. 7+ 5 C. 9 D. 6+ 5 E. 4+2 2 + 56. 下列设备中没有计算功能的是( )。A. 笔记本电脑 B. 掌上电脑 C. 智能手机D. 电子计算器 E. 液晶显示器7. Intel的首颗64 位处理器是( )。A. 8088 B. 8086 C. 80386 D. 80486 E. Pentium8. 常见的邮件传输服务器使用( )协议发送邮件。A. HTTP B. SMTP C. TCP D. FTP E. POP39. 不能

4、在Linux 上使用的网页浏览器是( )。A. Internet Explore B. Netscape C. Opera D. Firefox E. Mozilla10. 一位艺术史学家有20000 幅1024 * 768 的真彩色图像,如果将这些图像以位图形式保存在CD 光盘上(一张CD 光盘的容量按600M计算),大约需要( )张CD光盘。A. 1 B. 10 C. 100 D. 1000 E. 10000二、不定项选择题(共10题,每题1.5分,共计15分。多选或少选均不得分)。11. 设A = true,B = false,C = false,D = true,以下逻辑运算表达式值为

5、真的有( )。A. (A B )(C D ) B. (A B ) C ) D C. A(B C ) D )D. (A(B C ) D E. (A B )(C D )12. (3725)8 + (B)16的运算结果是( )。A. (3736)8 B. (2016)10 C. (11111100000)2 D. (3006)10 E. (7E0)1613. 二叉树T的宽度优先遍历序列为A B C D E F G H I,已知A是C的父结点,D 是G 的父结点,F 是I 的父结点,树中所有结点的最大深度为3(根结点深度设为0),可知E的父结点可能是( )。A. A B. B C. C D. D E.

6、 F14. 设栈S的初始状态为空,元素a, b, c, d, e, f, g依次入栈,以下出栈序列不可能出现的有( )。A. a, b, c, e, d, f, g B. b, c, a, f, e, g, d C. a, e, c, b, d, f, gD. d, c, f, e, b, a, g E. g, e, f, d, c, b, a15. 下列外设接口中可以通过无线连接的方式连接设备的是( )。A. USB 2.0 高速版 B. 红外 C. 蓝牙 D. 串口 E. IEEE 802.11g 无线网卡16. 处理器A 每秒处理的指令数是处理器B 的2 倍。某一特定程序P 分别编译为处

7、理器A和处理器B 的指令,编译结果处理器A 的指令数是处理器B 的4 倍。已知程序P 的算法时间复杂度为O(n2),如果处理器A执行程序P时能在一小时内完成的输入规模为n,则处理器B执行程序P时能在一小时内完成的输入规模为( )。A. 4 * n B. 2 * n C. n D. n / 2 E. n / 417. 以下哪个(些)不是计算机的输出设备( )。A. 鼠标 B. 显示器 C. 键盘 D. 扫描仪 E. 绘图仪18. 以下断电之后将不能保存数据的有( )。A. 硬盘 B. 寄存器 C. 显存 D. 内存 E. 高速缓存19. 下列活动中属于信息学奥赛系列活动的是( )。A. NOIP

8、 B. NOI C. IOI D. 冬令营 E. 国家队选拔赛20. 下列关于高级语言的说法正确的有( )。A. Ada 是历史上的第一个高级语言 B. Pascal和C都是编译执行的高级语言C. C+是历史上的第一个支持面向对象的语言 D. 编译器将高级语言程序转变为目标代码E. 高级语言程序比汇编语言程序更容易从一种计算机移植到另一种计算机上三问题求解(请在空格处填上答案,每空5分,共计10分)1. 将数组32, 74, 25, 53, 28, 43, 86, 47中的元素按从小到大的顺序排列,每次可以交换任意两个元素,最少需要交换次。2. 取火柴游戏的规则如下:一堆火柴有N根,A、B两人

9、轮流取出。每人每次可以取1 根或2 根,最先没有火柴可取的人为败方,另一方为胜方。如果先取者有必胜策略则记为1,先取者没有必胜策略记为0。当N 分别为100,200,300,400,500 时,先取者有无必胜策略的标记顺序为(回答应为一个由0 和/或1 组成的字符串)。四阅读程序(共4题,每题8分,共计32 分)=PASCAL语言=1 vara, b, c, p, q : integer;r : array0.2 of integer;beginread(a, b, c);p := a div b div c;q := b - c + a + p;r0 := a * p div q * q;r

10、1 := r0 * (r0 - 300);if (3 * q - p mod 3 = r0) and (r2 = r2) thenr1 := rr0 div p mod 2else r1 := q mod p;writeln(r0 - r1);end.输入:100 7 3输出:2 vara : array 1.50 of integer;n, i, sum : integer;procedure work(p, r: integer);vari, j, temp : integer;beginif p = ar then begininc(i);temp := ai; ai := aj; aj

11、 := temp;end;temp := ai + 1; ai + 1 := ar; ar := temp;work(p, i);work(i + 2, r);end;end;beginread(n);for i := 1 to n do read(ai);work(1, n);for i := 1 to n - 1 do sum := sum + abs(ai + 1 - ai);writeln(sum);end.输入:10 23 435 12 345 3123 43 456 12 32 -100输出:3 varstr : string;len, i, j : integer;nchr :

12、array 0.25 of integer;mmin : char;beginmmin := z;readln(str);len := length(str);i := len;while i = 2 do beginif stri - 1 stri - 1) and (strj mmin) thenmmin := strj;inc(nchrord(strj) - ord(a);end;dec(nchrord(mmin) - ord(a);inc(nchrord(stri - 1) - ord(a);write(mmin);for i := 0 to 25 dofor j := 1 to nc

13、hri dowrite(chr(i + ord(a);writeln;end.输入:zzyzcccbbbaaa输出:4. varn : longint;function g(k : longint) : longint;beginif k = 1 then g := kelse g := (2002 * g(k - 1) + 2003 * g(k - 2) mod 2005;end;beginread(n);writeln(g(n);end.输入:2005输出:=C语言=1 #include int main() int a, b, c, p, q, r3;scanf(“%d%d%d”, &a

14、, &b, &c);p = a / b / c;q = b c + a + p;r0 = a * p / q * q;r1 = r0 * (r0 300);if (3 * q p % 3 = r0 & r2 = r2)r1 = rr0 / p % 2;elser1 = q % p;printf(“%dn”, r0 r1);return 0;输入:100 7 3输出:2 #include #include int a50;void work(int p, int r) if (p r) int i = p - 1, j, temp;for (j = p; j = ar) i+;temp = ai

15、; ai = aj; aj = temp;temp = ai + 1; ai + 1 = ar; ar = temp;work(p, i);work(i + 2, r);int main() int n, i, sum = 0;scanf(%d, &n);for (i = 0; i n; i+) scanf(%d, &(ai);work(0, n - 1);for (i = 0; i n - 1; i+) sum += abs(ai + 1 - ai);printf(%dn, sum);return 0;输入:10 23 435 12 345 3123 43 456 12 32 -100输出:

16、3 #include#includeint main()char str60;int len, i, j, chr26;char mmin = z;scanf(%s, str);len = strlen(str);for (i = len - 1; i = 1; i-)if (stri - 1 stri) break;if (i = 0) printf(No result!n);return 0;for (j = 0; j i - 1; j+) putchar(strj);memset(chr, 0, sizeof(chr);for (j = i; j stri - 1 & strj mmin

17、)mmin = strj;chrstrj - a+;chrmmin - a-;chrstri - 1 - a+;putchar(mmin);for(i = 0; i 26; i+)for(j = 0; j chri; j+)putchar(i + a);putchar(n);return 0;输入:zzyzcccbbbaaa输出:4. #include long g(long k) if (k = k then break;num := ;end;if then isok := trueelse isok := false;end;beginreadln(n, k);right := 0;fo

18、r i := 1 to n do beginreadln(leni);if right leni then right := leni;end;inc(right); ;while right do beginmid := (left + right) div 2;if then right := midelse left := mid;end;writeln(left);end.2N叉树题目描述:我们都了解二叉树的先根遍历,中根遍历和后根遍历。当知道先根遍历的结果和中根遍历结果的时候,我们可以唯一的确定二叉树;同样的,如果知道了后根遍历的结果和中根遍历结果,二叉树也是唯一确定的。但是如果只知

19、道先根遍历和后根遍历的结果,二叉树就不是唯一的了。但是我们可以计算满足条件的不同二叉树一共有多少个。这不是一个很困难的问题,稍微复杂一点,我们把这个问题推广到N叉树。我们用小写英文字母来表示N 叉树的结点,不同的结点用不同的字母表示。比如,对于4叉树,如果先根遍历的结果是abdefgc,后根遍历的结果是defgbca,那么我们可以得到6个不同的4叉树(如下图)。输入:输入数据包括3行。第一行是一个正整数N(2 N 20),表示我们要考虑N叉树。第二行和第三行分别是两个字符串序列,分别表示先根遍历和后根遍历的结果。输出:输出不同的N叉树的数目。题目中给的数据保证得到的结果小于231。输入样例:4

20、abdefgcdefgbca输出样例:6程序:varstr1, str2 : string;N, len : integer;com : array0.100, 0.100 of longint;function getcom(x, y : integer) : longint;beginif (y = 0) or (x = y) then else if comxy 0 then getcom := comxyelse begincomxy := getcom(x - 1, y)+ ;getcom := comxy;end;end;function count(a, b, c : integ

21、er) : longint;varsum : longint;k, s, t, p : integer;beginsum := 1; k := 0; s := a + 1; t := c;if a = b then count := 1else beginwhile s = b do beginp := t;while str1s str2t do inc(t);sum := sum * count(s, s + t - p, p);s := ; ; inc(k);end;count := * getcom(N, k);end;end;beginreadln(N); readln(str1);

22、 readln(str2);len := length(str1);writeln(count( );end.=C语言=1木材加工题目描述:木材厂有一些原木,现在想把这些木头切割成一些长度相同的小段木头(木头有可能有剩余),需要得到的小段的数目是给定了的。当然,我们希望得到的小段越长越好,你的任务是计算能够得到的小段木头的最大长度。木头长度的单位是cm。原木的长度都是正整数,我们要求切割得到的小段木头的长度也是正整数。输入:第一行是两个正整数N和K(1 N 10000,1 K 10000),N是原木的数目,K是需要得到的小段的数目。接下来的N行,每行有一个1到10000之间的正整数,表示一根原

23、木的长度。输出:输出能够切割得到的小段的最大长度。如果连1cm长的小段都切不出来,输出”0”。输入样例:3 7232124456输出样例:114程序:#include int n, k, len10000;int isok(int t) int num = 0, i;for (i = 0; i = k) break;num = ;if ( ) return 1;else return 0;int main() int i, left, right, mid;scanf(%d%d, &n, &k);right = 0;for (i = 0; i n; i+) scanf(%d, &(leni);

24、if (right leni) right = leni;right+; ;while ( right) mid = (left + right) / 2;if ( ) right = mid;else left = mid;printf (%dn, left);return 0;2N叉树题目描述:我们都了解二叉树的先根遍历,中根遍历和后根遍历。当知道先根遍历的结果和中根遍历结果的时候,我们可以唯一的确定二叉树;同样的,如果知道了后根遍历的结果和中根遍历结果,二叉树也是唯一确定的。但是如果只知道先根遍历和后根遍历的结果,二叉树就不是唯一的了。但是我们可以计算满足条件的不同二叉树的一共有多少个。这不是一个很困难的问题,稍微复杂一点,我们把这个问题推广到N叉树。我们用小写英文字母来表示N 叉树的结点,不同的结点用不同的字母表示。比如,对于4叉树,如果先根遍历的结果是abdefgc,后根遍历的结果是defgbca,那么我们可以得到6个不同的4叉树(如下图)。输入:输入数据包括3行。第一行是一个正整数N(1 N 20),表示我们要考虑N叉树。第二行和第三行分别是两个字符串序列,分别表示先根遍历和后根遍历的结果。输出:输出不同的N叉树的数目。

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2