• 论坛网址:https://dianbai.wiki(可微信分享)、https://0668.es、https://0668.cc(全加密访问)

全国青少年信息学奥林匹克联赛noip (1人在浏览)

颜海峰

幼儿园
注册
2008-08-16
帖子
2
反馈评分
0
点数
0

全国信息学奥林匹克联赛
[url]
第十一届全国青少年信息学奥林匹克联赛初赛试题
( 提高组 C 语言 二小时完成 )

● ● 全部试题答案均要求写在答卷纸上,写在试卷纸上一律无效 ●●

一、 单项选择题 (共10题,每题1.5分,共计15分。每题有且仅有一个正确答案.)。

1. 字符串“ababacbab”和字符串“abcba”的最长公共子串是(B )。
A. abcba . Bcba C. abc D. ab E. bcba

2. 设全集I = {a, b, c, d, e, f, g, h},集合 = {a, b, c, d, e, f}, = {c, d, e}, = {a, d},那么集合 为( A)。
A. {c, e} B. {d, e} C. {e} D. {c, d, e} E. {d, f}

3. 以下二进制数的值与十进制数23.456的值最接近的是(D )。
A. 10111.0101 B. 11011.1111 C. 11011.0111 D. 10111.0111 E. 10111.1111

4. 完全二叉树的结点个数为4 * N + 3,则它的叶结点个数为( E)。
A. 2 * N B. 2 * N - 1 C. 2 * N + 1 D. 2 * N - 2 E. 2 * N + 2

5. 平面上有五个点A(5, 3), B(3, 5), C(2, 1), D(3, 3), E(5, 1)。以这五点作为完全图G的顶点,每两点之间的直线距离是图G中对应边的权值。图G的最小生成树中的所有边的权值综合为( D)。
A. 8 B. 7+ C. 9 D. 6+ E. 4+2 +

6. 下列设备中没有计算功能的是( E。
A. 笔记本电脑 B. 掌上电脑 C. 智能手机
D. 电子计算器 E. 液晶显示器

7. Intel的首颗64位处理器是(E )。
A. 8088 B. 8086 C. 80386 D. 80486 E. Pentium

8. 常见的邮件传输服务器使用(B )协议发送邮件。
A. HTTP B. SMTP C. TCP D. FTP E. POP3

9. 不能在Linux上使用的网页浏览器是(A )。
A. Internet Explore B. Netscape C. Opera D. Firefox E. Mozilla

10. 一位艺术史学家有20000幅1024 * 768的真彩色图像,如果将这些图像以位图形式保存在CD光盘上(一张CD光盘的容量按600M计算),大约需要(C )张CD光盘。
A. 1 B. 10 C. 100 D. 1000 E. 10000

二、 不定项选择题 (共10题,每题1.5分,共计15分。多选或少选均不得分)。

11. 设A = true,B = false,C = false,D = true,以下逻辑运算表达式值为真的有(CDE )。
A. (A∧∨(C∧D) B. ((A∧∨C)∧D C. A∧((B∨C)∨D)
D. (A∧(B∨C))∨D E. (A∨∧(C∨D)

12. (3725)8 + (B)16的运算结果是(BCE )。
A. (3736)8 B. (2016)10 C. (11111100000)2 D. (3006)10 E. (7E0)16

13. 二叉树T的宽度优先遍历序列为A B C D E F G H I,已知A是C的父结点,D是G的父结点,F是I的父结点,树中所有结点的最大深度为3(根结点深度设为0),可知E的父结点可能是(BC )。
A. A B. B C. C D. D E. F

14. 设栈S的初始状态为空,元素a, b, c, d, e, f, g依次入栈,以下出栈序列不可能出现的有(CE )。
A. a, b, c, e, d, f, g B. b, c, a, f, e, g, d C. a, e, c, b, d, f, g
D. d, c, f, e, b, a, g E. g, e, f, d, c, b, a

15. 下列外设接口中可以通过无线连接的方式连接设备的是(BCE )。
A. USB 2.0 高速版 B. 红外 C. 蓝牙 D. 串口 E. IEEE 802.11g 无线网卡

16. 处理器A每秒处理的指令数是处理器B的2倍。某一特定程序P分别编译为处理器A和处理器B的指令,编译结果处理器A的指令数是处理器B的4倍。已知程序P的算法时间复杂度为O(n2),如果处理器A执行程序P时能在一小时内完成的输入规模为n,则处理器B执行程序P时能在一小时内完成的输入规模为(B )。
A. 4 * n B. 2 * n C. n D. n / 2 E. n / 4

17. 以下哪个(些)不是计算机的输出设备(ACD )。
A. 鼠标 B. 显示器 C. 键盘 D. 扫描仪 E. 绘图仪

18. 以下断电之后将不能保存数据的有(BCDE )。
A. 硬盘 B. 寄存器 C. 显存 D. 内存 E. 高速缓存

19. 下列活动中属于信息学奥赛系列活动的是(ABCDE )。
A. NOIP B. NOI C. IOI D. 冬令营 E. 国家队选拔赛

20. 下列关于高级语言的说法正确的有(BDE )。
A. Ada是历史上的第一个高级语言
B. Pascal和C都是编译执行的高级语言
C. C++是历史上的第一个支持面向对象的语言
D. 编译器将高级语言程序转变为目标代码
E. 高级语言程序比汇编语言程序更容易从一种计算机移植到另一种计算机上

三.问题求解(请在空格处填上答案,每空5分,共计10分)

1. 将数组{32, 74, 25, 53, 28, 43, 86, 47}中的元素按从小到大的顺序排列,每次可以交换任意两个元素,最少需要交换 5 次。

2. 取火柴游戏的规则如下:一堆火柴有N根,A、B两人轮流取出。每人每次可以取1根或2根,最先没有火柴可取的人为败方,另一方为胜方。如果先取者有必胜策略则记为1,先取者没有必胜策略记为0。当N分别为100,200,300,400,500时,先取者有无必胜策略的标记顺序为 11011 (回答应为一个由0和/或1组成的字符串)。

四.阅读程序(共4题,每题8分,共计32分)

1. #include <stdio.h>
int main() {
int a, b, c, p, q, r[3];
scanf(“%d%d%d”, &a, &b, &c);
p = a / b / c;
q = b C c + a + p;
r[0] = a * p / q * q;
r[1] = r[0] * (r[0] C 300);
if (3 * q C p % 3 <= r[0] && r[2] == r[2])
r[1] = r[r[0] / p % 2];
else
r[1] = q % p;
printf(“%d\n”, r[0] C r[1]);
return 0;
}
输入:100 7 3
输出: -7452

2. #include <stdio.h>
#include <math.h>
int a[50];
void work(int p, int r) {
if (p < r) {
int i = p - 1, j, temp;
for (j = p; j < r; j++) {
if (a[j] >= a[r]) {
i++;
temp = a; a = a[j]; a[j] = temp;
}
}
temp = a[i + 1]; a[i + 1] = a[r]; a[r] = 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", &(a));
work(0, n - 1);
for (i = 0; i < n - 1; i++) sum += abs(a[i + 1] - a);
printf("%d\n", sum);
return 0;
}
输入:10 23 435 12 345 3123 43 456 12 32 -100
输出: 3223

3. #include<stdio.h>
#include<string.h>
int main(){
char str[60];
int len, i, j, chr[26];
char mmin = 'z';
scanf("%s", str);
len = strlen(str);
for (i = len - 1; i >= 1; i--)
if (str[i - 1] < str) break;
if (i == 0) {
printf("No result!\n");
return 0;
}
for (j = 0; j < i - 1; j++) putchar(str[j]);
memset(chr, 0, sizeof(chr));
for (j = i; j < len; j++) {
if (str[j] > str[i - 1] && str[j] < mmin)
mmin = str[j];
chr[str[j] - 'a']++;
}
chr[mmin - 'a']--;
chr[str[i - 1] - 'a']++;
putchar(mmin);
for(i = 0; i < 26; i++)
for(j = 0; j < chr; j++)
putchar(i + 'a');
putchar('\n');
return 0;
}
输入:zzyzcccbbbaaa
输出: zzzaaabbbcccy

4. #include <stdio.h>
long g(long k) {
if (k <= 1) return k;
return (2002 * g(k - 1) + 2003 * g(k - 2)) % 2005;
}
int main() {
long n;
scanf("%ld", &n);
printf("%ld\n", g(n));
return 0;
}
输入:2005
输出: 31

五.完善程序 (前5空,每空2分,后6空,每空3分,共28分)

1.木材加工
题目描述:
木材厂有一些原木,现在想把这些木头切割成一些长度相同的小段木头(木头有可能有剩余),需要得到的小段的数目是给定了的。当然,我们希望得到的小段越长越好,你的任务是计算能够得到的小段木头的最大长度。
木头长度的单位是cm。原木的长度都是正整数,我们要求切割得到的小段木头的长度也是正整数。
输入:
第一行是两个正整数N和K(1 ≤ N ≤ 10000,1 ≤ K ≤ 10000),N是原木的数目,K是需要得到的小段的数目。
接下来的N行,每行有一个1到10000之间的正整数,表示一根原木的长度。
输出:
输出能够切割得到的小段的最大长度。如果连1cm长的小段都切不出来,输出”0”。
输入样例:
3 7
232
124
456
输出样例:
114
程序:
#include <stdio.h>
int n, k, len[10000];
int isok(int t) {
int num = 0, i;
for (i = 0; i < n; i++) {
if (num >= k) break;
num = ①num+len/t ;
}
if ( ②num>=k ) 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", &(len));
if (right < len) right = len;
}
right++;
③left=0 ;
while ( ④left+1 < right) {
mid = (left + right) / 2;
if ( ⑤!isol(mid) (或者isol(mid)==0) ) right = mid;
else left = mid;
}
printf ("%d\n", left);
return 0;
}

2.N叉树
题目描述:
我们都了解二叉树的先根遍历,中根遍历和后根遍历。当知道先根遍历的结果和中根遍历结果的时候,我们可以唯一的确定二叉树;同样的,如果知道了后根遍历的结果和中根遍历结果,二叉树也是唯一确定的。但是如果只知道先根遍历和后根遍历的结果,二叉树就不是唯一的了。但是我们可以计算满足条件的不同二叉树的一共有多少个。这不是一个很困难的问题,稍微复杂一点,我们把这个问题推广到N叉树。
我们用小写英文字母来表示N叉树的结点,不同的结点用不同的字母表示。比如,对于4叉树,如果先根遍历的结果是abdefgc,后根遍历的结果是defgbca,那么我们可以得到6个不同的4叉树(如下图)。

输入:
输入数据包括3行。
第一行是一个正整数N(1 ≤ N ≤ 20),表示我们要考虑N叉树。
第二行和第三行分别是两个字符串序列,分别表示先根遍历和后根遍历的结果。
输出:
输出不同的N叉树的数目。题目中给的数据保证得到的结果小于231。
输入样例:
4
abdefgc
defgbca
输出样例:
6
程序:
#include <stdio.h>
#include <string.h>
char str1[100], str2[100];
int N;
long com[100][100];
long getcom(int x, int y) {
if (y == 0 || x == y) ①return 1 (或者 return 1L,或者 return 1l) ;
else if (com[x][y] != 0) return com[x][y];
else {
com[x][y] = getcom(x - 1, y)+ ②getcom(x-1,y-1) ;
return com[x][y];
}
}
long count(int a, int b, int c){
long sum = 1;
int k = 0;
int s = a + 1, t = c, p;
if (a == return 1;
while(s <= {
p = t;
while(str1 != str2[t]) t++;
sum = sum * count(s, s + t - p, p);
s = ③s+t-p+1 ;
④t++ (或者++t/t=t+1/t+=1) ;
k++;
}
return ⑤ sum * getcom(N, k);
}
int main(){
int len;
scanf("%d", &N);
scanf("%s%s", str1, str2);
len = strlen(str1);
printf("%ld\n", count( ⑥0,len-1,0 ));
return 0;
}
 

附件

  • ch01.pdf
    644 KB · 查看: 100

正在浏览此帖子的用户

后退
顶部