1995-2011NOIP C语言普及组试题和答案

一定要有答案啊
!!!
我邮箱:843319656@qq.com
是初赛的

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

1. 在以下各项中。( )不是CPU的组成部分。
A. 控制器 B. 运算器 C. 寄存器 D. ALU E. RAM

2. BIOS(基本输入输出系统)是一组固化在计 )上一个ROM芯片上的程序。
A. 控制器 B. CPU C. 主板 D. 内存条 E. 硬盘

3. 在下面各世界顶级的奖项中,为计算机科学与技术领域作出杰出贡献的科学家设立的奖项是( )。
A. 沃尔夫奖 B. 诺贝尔奖 C. 菲尔兹奖
D. 图灵奖 E. 南丁格尔奖

4.在编程时(使用任一种高级语言,不一定是C),如果需要从磁盘文件中输入一个很大的二维数组(例
如 1000*1000 的 double 型数组),按行读(即外层循环是关于行的)与按列读(即外层循环是关于
列的)相比,在输入效率上( )。
A. 没有区别 B. 有一些区别,但机器处理速度很快,可忽略不计
C. 按行读的方式要高一些 D. 按列读的方式要高一些 E. 取决于数组的存储方式。

5.在C语言中,表达式21^2的值是( )
A. 441 B. 42 C.23 D.24 E.25

6.在C语言中,判断a不等于0且b不等于0的正确的条件表达式是( )
A. !a==0 || !b==0 B. !((a==0)&&(b==0)) C. !(a==0&&b==0)
D. a!=0 || b!=0 E. a && b

7.某个车站呈狭长形,宽度只能容下一台车,并且只有一个出入口。已知某时刻该车站状态为空,从
这一时刻开始的出入记录为:“进,出,进,进,进,出,出,进,进 ,出”。假设车辆入站的
顺序为1,2,3,……,则车辆出站的顺序为( )。
A. 1, 2, 3, 4, 5 B. 1, 2, 4, 5, 7 C. 1, 4, 3, 7, 6
D. 1, 4, 3, 7, 2 E. 1, 4, 3, 7, 5

8.高度为n的均衡的二叉树是指:如果去掉叶结点及相应的树枝,它应该是高度为n-1的满二叉树。
1

在这里,树高等于叶结点的最大深度,根结点的深度为 0,如果某个均衡的二叉树共有 2381 个结点,
则该树的树高为( )。
10
– 1
A. 10 B. 11 C. 12 D. 13 E. 2

9. 与十进制数1770.625 对应的八进制数是( )。
A. 3352.5 B. 3350.5 C. 3352.1161
D. 3350.1151 E. 前4个答案都不对

10.将5个数的序列排序,不论原先的顺序如何,最少都可以通过( )次比较,完成从小到大的排序。
A. 6 B. 7 C. 8 D. 9 E. 10

二、 不定项选择题 (共10 题,每题1.5 分,共计15 分。每题正确答案的个数大于或等于1。多选
或少选均不得分)。

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

+ (32) 的结果是( )。
12. (2010)
16 8
B. (202A)
A. (8234)
10 16
D. (2042)
C. (100000000110)
2 16

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

14. 已知6 个结点的二叉树的先根遍历是1 2 3 4 5 6(数字为结点的编号,以下同),后根遍历是
3 2 5 6 4 1,则该二叉树的可能的中根遍历是( )
A. 3 2 1 4 6 5 B. 3 2 1 5 4 6
C. 2 3 1 5 4 6 D. 2 3 1 4 6 5

15. 在下列各数据库系统软件中,以关系型数据库为主体结构的是( )。
A. ACCESS B. SQL Server
C. Oracle D. Foxpro

16.在下列各软件中,属于NOIP竞赛(复赛)推荐使用的语言环境有( )。
A. gcc/g++ B. Turbo Pascal
C. Turbo C D. free pascal
2

17. 以下断电之后将不能保存数据的有( )。
A. 硬盘 B. ROM C. 显存 D. RAM

18. 在下列关于计算机语言的说法中,正确的有( )。
A. Pascal和C都是编译执行的高级语言
B. 高级语言程序比汇编语言程序更容易从一种计算机移植到另一种计算机上
C. C++是历史上的第一个支持面向对象的计算机
D. 高级语言比汇编语言更高级,是因为它的程序的运行效率更高

19. 在下列关于计算机算法的说法中,正确的有( )。
A. 一个正确的算法至少要有一个输入
B. 算法的改进,在很大程度上推动了计算机科学与技术的进步
C. 判断一个算法的好坏,主要依据它在某台计算机上具体实现时的运行时间
D. 目前仍然存在许多涉及到国计民生的重大课题,还没有找到能够在计算机上实施的有效算法

20. 在下列关于青少年信息学竞赛的说法中,你赞成的是( )(本题 0分,答题一律满分)。
A. 举行信息学竞赛的目的,是为了带动广大青少年学科学、爱科学,为造就一大批优秀的计算机科学
与技术人才奠定良好的基础
B. 如果竞赛优胜者不能直接保送上大学,我今后就不再参与这项活动了
C. 准备竞赛无非要靠题海战术,为了取得好成绩,就得拼时间、拼体力
D. 为了取得好成绩,不光要看智力因素,还要看非智力因素。优秀选手应该有坚韧不拔的意志,有
严谨求实的作风,既要努力奋进,又要胜不骄败不馁

三.问题求解(共2题,每题5分,共计10分)

1.将2006个人分成若干不相交的子集,每个子集至少有3个人,并且:
(1)在每个子集中,没有人认识该子集的所有人。
(2)同一子集的任何3个人中,至少有2个人互不认识。
(3)对同一子集中任何2个不相识的人,在该子集中恰好只有1个人认识这两个人。
则满足上述条件的子集最多能有___________个?

2.将边长为n 的正三角形每边n 等分,过每个分点分别做另外两边的平行线,得到若干个正三角形,
我们称为小三角形。正三角形的一条通路是一条连续的折线,起点是最上面的一个小三角形,终点是最
下面一行位于中间的小三角形。在通路中,只允许由一个小三角形走到另一个与其有公共边的且位于同
一行或下一行的小三角形,并且每个小三角形不能经过两次或两次以上(图中是 n=5 时一条通路的例
子)。设n=10,则该正三角形的不同的通路的总数为_____________。
3

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

1. #include <stdio.h>
int main()
{int i,u[4],v[4],x,y=10;
for(i=0;i<=3;i++)
scanf("%d", &u);
v[0]=(u[0]+u[1]+u[2]+u[3])/7;
v[1]=u[0]/((u[1]-u[2])/u[3]);
v[2]=u[0]*u[1]/u[2]*u[3];
v[3]=v[0]*v[1];
x=(v[0]+v[1]+2)-u[(v[3]+3)%4];
if(x>10)
y+= (v[2]*100-v[3])/(u[u[0]%3]*5);
else
y+=20+(v[2]*100-v[3])/(u[v[0]%3]*5);
printf("%d,%d\n", x,y);
return 0;
} /*注:本例中,给定的输入数据可以避免分母为0或下标越界。 */
输入:9 3 9 4
输出:_______________

2.#include <stdio.h>
main()
;
long t;
for (i=0;i<=4;i++)
{t=1;
for(j=1;j<m;j++) t*=2;
printf("%ld ",(t*2-1)*t);
}
4

printf("\n");
}
输出:____________________

3.#include "stdio.h"
#define N 7
int fun1(char s[],char a,int n)
{int j;
j=n;
while(a<s[j] && j>0) j--;
return j;
}
int fun2(char s[],char a,int n)
{int j;
j=1;
while(a>s[j] && j<=n) j++;
return j;
}
void main()
{char s[N+1];
int k,p;
for(k=1;k<=N;k++)
s[k]='A'+2*k+1;
p=fun1(s,'M',N);
printf(“%d\n”,p+fun2(s,'M',N));
}
输出:_____________

4.#include <stdio.h>
void digit(long n,long m)
{if(m>0)
printf("%2ld",n%10);
if(m>1)
digit(n/10,m/10);
printf("%2ld",n%10);
}
main()
{long x,x2;
5

printf("Input a number:\n"); scanf("%ld",&x);
x2=1;
while(x2<x) x2*=10;
x2/=10;
digit(x,x2);
printf("\n");
}
输入:9734526
输出:______________________________

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

1.(选排列)下面程序的功能是利用递归方法生成从1到n(n<10)的n个数中取k(1<=k<=n)个数的
全部可能的排列(不一定按升序输出)。例如,当n=3,k=2时,应该输出(每行输出5个排列):
12 13 21 23 32
31
程序:
#include <stdio.h>
int n,k,a[10];
long count=0;
void perm2(int j)
{int i,p,t;
if( ① )
{for(i=k;i<=n;i++)
{count++;
t=a[k]; a[k]=a; a=t;
for( ② )
printf("%1d",a[p]); /* "%1d"中是数字1,不是字母l */
printf(" ");
t=a[k];a[k]=a;a=t;
if(count%5==0) printf("\n");
}
return;
}
for(i=j;i<=n;i++)
{t=a[j];a[j]=a;a=t;
③ ;
t=a[j]; ④ ;
6

}
}
main()
{int i;
printf("\nEntry n,k (k<=n):\n");
scanf("%d%d",&n,&k);
for(i=1;i<=n;i++) a=i;
⑤ ;
}

2.(TSP问题的交叉算子)TSP问题(Traveling Salesman Problem)描述如下:给定n个城
市,构成一个完全图,任何两城市之间都有一个代价(例如路程、旅费等),现要构造遍历所有城市的环
路,每个城市恰好经过一次,求使总代价达到最小的一条环路。
遗传算法是求解该问题的一个很有效的近似算法。在该算法中,一个个体为一条环路,其编码方法
之一是1 到n 这n 个数字的一个排列,每个数字为一个城市的编号。例如当n=5 时,“3 4 2 1 5”
表示该方案实施的路线为3->4->2->1->5->3。遗传算法的核心是通过两个个体的交叉操作,产生两
个新的个体。下面的程序给出了最简单的一种交叉算法。具体过程如下:
(1)选定中间一段作为互换段,该段的起止下标为t1,t2,随机生成t1,t2后,互换两段。
(2)互换后,在每个新的排列中可能有重复数字,因而不能作为新个体的编码,一般再做
(2.1) 将两个互换段中,共同的数字标记为0,表示已处理完。
(2.2) 将两个互换段中其余数字标记为1,按顺序将互换段外重复的数字进行替换。
例如:n=12,两个个体分别是:
a1: 1 3 5 4 * 2 6 7 9 * 10 12 8 11
a2: 3 2 1 12 * 6 7 10 11 * 8 5 4 9
t1=5,t2=8。上述每一行中,两个星号间的部分为互换段。假定数组的下标从1开始,互换后有:
a1: 1 3 5 4 * 6 7 10 11 * 10 12 8 11
a2: 3 2 1 12 * 2 6 7 9 * 8 5 4 9
然后,将数字6,7对应的项标记为0,星号内数字2,9,10,11对应的项标记为1,并且按顺序对
应关系为: 10<->2 ,11<->9。于是,将a1[9]=10替换为a1[9]=2,将a2[2]=2替换为a2[2]=10,
类似再做第2组替换。这样处理后,就得到了两个新个体:
a1: 1 3 5 4 6 7 10 11 2 12 8 9
a2: 3 10 1 12 2 6 7 9 8 5 4 11
(3)输出两个新个体的编码。
程序:
#include <stdio.h>
#include <stdlib.h>
#define N 20
int a1[N],a2[N],kz1[N],kz2[N],n;
7

int rand1(int k)
{int t=0;
while(t<2|| t>k)
t=(int)((double)rand()/RAND_MAX*k);
return t;
}
void read1(int a[],int m)

void wrt1(int a[],int m)

void cross(int a1[], int a2[],int t1, int t2, int n)
{int i,j,k,t,kj;
for(i=t1; i<=t2; i++)
① ;
{t=a1;
}
for(i=1;i<=n;i++)
if(i<t1 || i>t2)
kz1=kz2=-1;
else
② ;
for(i=t1;i<=t2;i++)
for(j=t1;j<=t2;j++)
if(a1==a2[j])
③ ; break;
{
}
for(i=t1;i<=t2;i++)
if(kz1==1)
{for(j=t1;j<=t2;j++)
if(kz2[j]==1)
{kj=j; break;
}
for(j=1;j<=n;j++)
④ )
if(
{a1[j]=a2[kj];break;
}
for(j=1;j<=n;j++)
⑤ )
if(
{a2[j]=a1; break;
8

}
kz1=kz2[kj]=0;
}
}
main()
{int k,t1,t2;
printf("input (n>5):\n"); scanf("%d",&n);
printf("input array 1 (%d'numbers):\n",n); read1(a1,n);
printf("input array 2 (%d'numbers):\n",n); read1(a2,n);
t1=rand1(n-1);
do
{t2=rand1(n-1);
}while(t1==t2);
if(t1>t2)
{k=t1; t1=t2; t2=k;
}

⑥2
wrt1(a1,n); wrt1(a2,n);
}
希望能有用追问

发邮箱,另外要2000-2011年的初赛试题,最好有1995-2011的

温馨提示:内容为网友见解,仅供参考
第1个回答  2012-09-26
noi.cn追问

打不开啊

第2个回答  2012-09-25
东西呢,这怎么只有一个标题?
第3个回答  2012-09-25
叫姐姐

1995-2011NOIP C语言普及组试题和答案
A. 硬盘 B. ROM C. 显存 D. RAM 18. 在下列关于计算机语言的说法中,正确的有( )。 A. Pascal和C都是编译执行的高级语言 B. 高级语言程序比汇编语言程序更容易从一种计算机移植到另一种计算机上 C. C++是历史上的第一个支持面向对象的计算机 D. 高级语言比汇编语言更高级,是因为它的程序的运行效率更高...

NOIP2011普及组复赛第二题瑞士轮C语言解答,急啊
NOIP2011普及组复赛第三题才是瑞士轮,这类题目耗费时间,提供C语言参考,转换C语言相对容易。使用头文件,定义变量N、R、Q,以及计数器Count1、Count2。创建玩家结构体数组p[200005]、p1[100002]、p2[100002]。定义cmp函数用于比较玩家s属性,当s相同时比较num。设置变量t1、t2为0。输入N、R、Q,初...

在今年的NOIP 2011 初赛试题中(普及组),有一个这样的题,请大家帮我解决...
答案:128 思路一:在这个八位的二进制中,有 偶数个1的数与有奇数个1的数是相对的 所以它们个数相等 因为有8位 所以这个二进制共用256种可能 除以2 便得到128 思路二:可以用组合的知识解:接在8个元素中组合取偶数个1 分别C(8,0)+C(8,2)+C(8,4)+C(8,6)+C(8,8)=128 ...

请提供NOIP历届C语言试题。邮箱zhibinxx@hotmail.com.谢谢。
C. 支持面向对象特性的语言称为面向对象的编程语言,目前较为流行的有C++、JAVA、C#等。D. 面向对象的程序设计的雏形来自于Simula语言,后来在SmallTalk语言的完善和标准化的过程中得到更多的扩展和对以前思想的重新注解。至今,SmallTalk语言仍然被视为面向对象语言的基础。18. 设T是一棵有n个顶点的树,下列说法正确的...

NOIP2013 Pascal普及组初赛试题答案
二大题:14种 s1=0 s2=1 s3=1 s4=1 一道题5分(第二题s1~s4需要全部答对,答错一个没分)三大题:3+5=8 6 7 4 一道题8分 四大题:n-p+i a[i]n i-p+1 a[i-p]cur<upper_bound a[root].right_child cur upper_bound 1 第三个答案和最后一个答案两分,其他的答案3分,一...

学C语言的NOIP问题
C 语言 === 1. ① ② ③ ④ 2. ① ② ③ ④ ⑤ 第九届全国青少年信息学奥林匹克联赛初赛试题 普及组参考答案 一. 选择一个正确答案代码(A\/B\/C\/D\/E),填入每题的括号内 (每题1.5分,多选无分, 共30 分) 题号1 2 3 4 5 6 7 8 9 10 选择C B D C E A B D C A 题号11 12 13 14...

“全国青少年信息学奥林匹克竞赛”
由中国计算机学会负责组织的全国青少年信息学奥林匹克联赛(NOIP)是全国信息学奥林匹克竞赛(NOI)整个系列中的一个重要组成部分,旨在向中学生普及计算机基础知识,培养计算机科学和工程领域的后备人才。普及的重点是根据中学生的特点,培养学生学习计算机的兴趣,使得他们对信息技术的一些核心内容有更多的了解,提高他们创造性地运...

NOIP2011年普及组试题哪里有
全国信息学奥林匹克联赛(NOIP2011)复赛普及组1.数字反转 (reverse.cpp\/c\/pas) 【问题描述】给定一个整数,请将该数各个位上数字反转得到一个新数。新数也应满足整数的常见形式,即除非给定的原数为零,否则反转后得到的新数的最高位数字不应为零(参见样例 2)。【输入】输入文件名为 reverse.in。输入共 1行...

求试题,17届NOIP(C语言)普及组初赛试题
printf("%c", tel[i]); else if ((tel[i] >= 'A') && (tel[i] <= 'Z')) printf("%c", map[tel[i] - 'A']); return 0; } 输入:CCF-NOIP-2011 输出:___ 3. #include <stdio.h> #include <string.h> #define SIZE 100 int main() { int n, i, sum, x, a[...

第十二届全国青少年信息学奥林匹克联赛普及组P语言试题及答案!
第十二届全国青少年信息学联赛(普及组)答案http:\/\/www.noi.cn\/noi\/showNews.jsp?newsId=200190000064 普及组(Pascal语言)参考答案与评分标准 一、单项选择题:(每题1.5分) 1. D 2. B 3. B 4. C 5. B 6.B 7. C 8. A 9. D 10. D 11. C 12. D 13. C 14. B 15. C 16. B 17. B ...

相似回答