找回密码
 立即注册
大科技语录:
查看: 2622|回复: 7

NOIP(2008.10.18)初赛留念帖

[复制链接]
发表于 2008-10-18 19:45 | 显示全部楼层 |阅读模式
今天是NOIP(National Olympiad in Informatics in Provinces/全国青少年信息学奥林匹克联赛)的初赛.
题目较往年来看比较简单,估计分数线或有很大的提高.
发表于 2008-10-18 23:22 | 显示全部楼层
的确较简单,我等小菜勉强能接受
过两天民间应该就有试题和答案出来了,到时候来贴
回复

使用道具 举报

 楼主| 发表于 2008-10-19 10:47 | 显示全部楼层
题目我没找到,不过一回家那答案就出来了.
一、单项选择题:(每题1.5分)
1. C      2. A      3. B      4. C      5. B
6. D      7. D      8. E      9. B      10. C
二、 不定项选择题 (共10题,每题1.5分,共计15分。每题正确答案的个数大于或等于1。多选或少选均不得分)。
11. ABD   12. AC                13. BC    14. B            15. ABC  
16. ABD   17. BCD    18. ABC   19. ACD   20. ABCD
三、问题求解:(共2题,每题5分,共计10分)
1.7
2.3060
四、阅读程序写结果(共4题,每题8分,共计32分)
1. 23 (信心题)
2. 1,3,2 (简单递归)
3. 132/213/231/312/321/ (全排列)
4. defghijxyzabc/hfizxjaybcccc (字符串替换)
五.完善程序 (前6空,每空3分,后5空,每空2分,共28分)
(说明:以下各程序填空可能还有一些等价的写法,各省可请本省专家审定和上机验证,不一定上报科学委员会审查)        
Pascal
1.        
① a[left]   
② a[j] < value (或a[j] <= value)   
③ a[i] > value (或a[i] >= value)  
④ a[i] := value;   
⑤ i,right,n   
⑥ FindKth(left, i, n)   
2.   
① inc(j); (或者j := j+1;)   
② a[i,j] > k   
③ a[i,j] < k   
④ answerx := i;   
⑤ answery := j;

C/C++
1.   
① a[left]  
② a[i] < value   
③ a[j] > value   
④ a[i] = value;   
⑤ i,right,n   
⑥ FindKth(left, i, n)   
   
2.   
① j++ ;  
② a[i][j] > k   
③ a[i][j] < k   
④ answerx = i;   
⑤ answery = j;

[[i] 本帖最后由 liota 于 2008-10-19 11:42 编辑 [/i]]
回复

使用道具 举报

发表于 2008-10-19 12:52 | 显示全部楼层
读答案有感
1.不定项没我想的那么恐怖,只是和选择一样难
2.为什么每次都栽在读程序第一题这种水题上...(第二题还递归错了?!)
3.可能得提前退役了

贴一下试题,来源:OIBH
一、    单项选择题(共10题,每题1.5分,共计15分。每题有且仅有一个正确答案)
1. 在以下各项中,()不是操作系统软件。
A.Solaris   B.Linux  C.Sybase  D.Windows Vista  E.Symbian

2.   微型计算机中,控制器的基本功能是()。
A.  控制机器的各个部件协调工作   B.实现算数运算与逻辑运算  C.存储各种控制信息
D.  获取外部信息     E.存放程序和数据

3.  设字符串S=“Olympic”,S的非空字串的数目是()。
A.29 B.28 C.16 D.17 E.7

4.  完全2叉树有2*N-1的结点,则它的叶子结点数目是()。
A.N-1  B.2*N  C.N  D.2^N-1 E.N/2

5.  将数组{8,23,4,16,77,-5,53,100}中元素从大到小按顺序排序,每次可以交换任意两个元素,最少要交换()次。
A.4  B.5  C.6 D.7  E.8

6.设栈S的初始状态为空,元素a,b,c,d,e,f依次入栈,出栈顺序为b,d,c,f,e,a那么栈容量至少应该是()
A.6   B.5   C.4   D.3   E.2

7.与十进制数28.5625相等的四进制数是()
A.123.21  B.131.22 C.130.22 D.130.21 E.130.20

8.递归过程和函数调用时,处理参数和返回地址,通常使用一种称为()的数据结构。
A.队列  B.多维数组  C.线性表  D.链表  E.栈

9.TCP/IP 是一组构成互联网基础的网络协议,字面上包括两组协议:传输控制协议(TCP)和网际互联协议(IP)。TCP/IP协议把Internet网络系统描述成具有4个层次功能的网络模型,其中提供源节点和目的节点之间的信息传输服务,包括寻址和路由器选择等功能的是()。
A.链路层  B.网络层  C.传输层 D.应用层 E.会话层

10.对有序数组{5,13,19,21,37,56,64,75,88,92,100}进行二分查找,等概率情况下,查找成功的平均查找长度(平均比较次数)是()。
A.35/11  B.34/11  C.33/11  D.32/11  E.34/10

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

11.下列关于图灵的说法正确的有()
A.图灵奖是美国计算机协会与1966年设立的,专门鼓励那些对计算机做出重要贡献的个人
B.图灵奖有“计算机界诺贝尔奖”之称。
C.迄今为止,还没有华裔计算机科学家获此殊荣。
D.图灵奖的名称取自计算机科学先驱、英国科学家阿兰、图灵。

12.计算机在工作过程中,若突然停电,()中不会丢失信息不会丢失。
A.硬盘  B.CPU  C.ROM  D.RAM

13.若A=true,B=false,C=true,D=false,以下逻辑运算表达式真的有()
A.(A∩B)D∪(C∩DD∪&not;A)  B.((&not;A∩B)D∪C) ∩&not;B  C.(BD∪CD∪D)VD∩A  D.A∩(D∪&not;C) ∩B

14.Web2.0是近年来互联网热门概念之一,其核心是互动与分享。下列网站中,()是典型的Web2.0的应用。
A.Sina  B.Flickr  C.Yahoo  D.GooGle

15.(2008)10+  (5B)16 的结果是()。
A.(833)16  B.(2099) 10 C. (4063)8 D.(100001100011)2

16.二叉树T,已知其先序遍历是1 2 4 3 5 7 6(数字为节点编号,以下同),后序遍历是4 2 7 5 6 3 1,则该二叉树的中根遍历是()
A.4 2 1 7 5 3 6  B.  2 4 1 7 5 3 6  C. 4 2 1 7 5 6 4  D. 2 4 1 5 7 3 6

17.面向对象的程序设计(Object-Oriented Programming)是一种程序设计的方法论,它将对象作为程序设计的基本单元,将数据和程序封装在对象中,以提高软件的重用性、灵活性、和扩展性。下面关于面向对象的程序设计说法中正确的是()。
A.面向对象的程序设计方法通常采用自顶向下的设计方法进行设计。
B.面向对象的程序设计方法具有继承性(inheritance)、封装性(encapsulation)、多态性(polymorphism)等几大特点。
C.支持面向对象特性称为面向对象的编程语言,目前较为流行的有C++,JAVA,C#等。
D.面向对象的程序设计的雏形来自于Simula语言,后来在Smalltalk语言的完善和标准化的过程中得到更多的扩展和对以前的思想的重新注解。至今,Smalltalk语言任然被视为面向对象的基础。

18.设T是一棵有n个定点的树,以下说法正确的是()。
A.T是联通的,无环的。
B.T是联通的,有n-1条边。
C.T是无环的,有n-1条边。
D.以上都不对。

19.NOIP竞赛推荐使用的语言环境有()。
A.Dev-C++  B.Visual C++  C. free pascal  D.lazarus

20.在下列防火墙(firewall)的说法中,正确的有()。
A.防火墙是一项协助确保信息安全的设备,其会依照特定的规则,允许或是限制数据通过。
B.防火墙可能是一台专属硬件或是安装在一般硬件上的一套软件。
C.网络层防火墙可以视为一种IP数据包过滤器,只允许符合特定规定的数据包通过,其余的一概禁止穿越防火墙。
D.应用层防火墙是在TCP/IP的“应用层”上工作,可以拦截进出某应用程序的所有数据包。

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

1.有6个城市,任何两个城市之间有一条道路连接,6个城市之间两两之间的距离如下表表示,则城市1到城市6的最短距离为(   )。
城市1   城市2  城市3  城市4  城市5  城市6
城市1  0     2    3     1    12   15
城市2  2     0    2     5     3   12
城市3  3     2    0     3     6    5
城市4  1     5    3     0     7    9
城市5  12    3    6     7     0    2
城市6  15    12   5     9     2    0

2.书架上有21本书,编号从1 到 21 从中选4 本,其中每两本的编号都不相邻的选法一共有(   )。

四.阅读程序写结果(共4题,每题8分,共计32分)
1.
#include <stdio.h>
int main()
{
  int i,a,b,c,d,f[4];
  for(i=0;i<4;i++)
    scanf("%d",f);
    
  a=f[0]+f[1]+f[2]+f[3];
  a=a/f[0];
  b=f[0]+f[2]+f[3];
  b=b/a;
  c=(b*f[1]+a)/f[2];
  d=f[(b/c)%4];
  if(f[(a+b+c+d)%4]>f[2])
    printf("%d\n",a+b);
  else
    printf("%d\n",c+d);
  return 0;
}
输入:9  19  29  39
输出:

2.
#include <stdio.h>
void foo(int a,int b,int c)
{
  if(a>b)
    foo(c,a,b);
  else
    printf("%d,%d,%d\n",a,b,c);
}
int main()
{
  int a,b,c;
  scanf("%d %d %d",a,&b,&c);
  foo(a,b,c);
  return 0;
}
输入:2  1  3
输出:

3.
#include <stdio.h>
void f(int a,int b,int c)
{
  printf("%d%d%d/",a,b,c);
  if(a==3&b==2&&c==1)
    return;
  if(b<c)
    f(a,c,b);
  else if(a<b)
  {
    if(a<c)
      f(c,a,b);
    else
      f(b,c,a);
  }
}
int main()
{
  int a,b,c;
  scanf("%d %d %d",a,&b,&c);
  f(a,b,c);
  printf("\n");
  return 0;
}
输入:1 3 2
输出:

4.
#include <stdio.h>
#include <string.h>
int i,j,len;
char s[50];
int main()
{
  scanf("%s",s);
  len=strlen(s);
  for(i=0;i<len;++i)
  {
    if(s>='A'&s<='Z')s-='A'-'a';
  }
  for(i=0;i<len;++i)
  {
    if(s<'x')s+=3; else s+=-23;
  }
  printf("%s/",s);
  for(j=1;j<4;j++)
  {
    for(i=0;i<len-j;i=i+j)
    {
      s=s[i+j];
    }
  }
  printf("%s\n",s);
  return 0;
}
输入:ABCDEFGuvwxyz
输出:

五.完善程序(前6空,每空3分,后5空,每空2分,共28分)
1.(找第k大的数)给定一个长度为1000000的无序正整数序列,以及另一个数n(1<=n<=1000000),接下来以类似快速排序的方法找到序列中第n大的数(关于第n大的数:例如序列{1,2,3,4,5,6}中第3大的数是4)。

#include <stdlib.h>
#include <stdio.h>
int a[1000001],n,ans=-1;
void swap(int *a,int *b)
{
  int c;
  c=*a; *a=*b; *b=c;
}
int FindKth(int left,int right,int n)
{
  int tmp,value,i,j;
  if(left==right)return left;
  tmp=rand()%(right-left)+left;
  swap(a[tmp],&a[left]);
  value=  ①   
  i=left;
  j=right;
  while(i<j)
  {
    while(i<j&②)j--;
    if(i<j){a=a[j];j++;}else break;
    while(i<j&③)i++;
    if(i<j){a[j]=a;j--;}else break;
  }
  ④
  if(i<n)return FindKth(⑤) ;
  if(i>n)return ⑥
  return i;
}
int main()
{
  int i;
  int m=1000000;
  for(i=1;i<=m;i++)
    scanf("%d",n);
  ans=FindKth(1,m,n);
  printf("%d\n",a[ans]);
  return 0;
}

2.(矩阵中的数字) 有一个n*n(1<=n<=5000)的矩阵a,对于1<=i<n, 1<=j<n, a[i,j]<a[i+1,j], a[j,i]<a[j,i+1]。即矩阵中左右相邻的两个元素,右边的元素一定比左边的大。上下相邻的两个元素,下面的元素一定比上面的大。给定矩阵a中的一个数字k,找出k所在的行列(注意:输入数据保证矩阵中的数各不相同)。

#include <stdio.h>
int n,k,answerx,answery;
int a[5001][5001];
void FindKPosition()
{
  int i=n,j=n;
  while(j>0)
  {
    if(a[n][j]<k)break;
    j--;
  }
  ①
  while(a[j]!=k)
  {
    while(②&i>1)i--;
    while(③&j<=n)j++;
  }
  ④
  ⑤
}
int main()
{
  int i,j;
  scanf("%d",n);
  for(i=1;i<=n;i++)
    for(j=1;j<=n;j++)
      scanf("%d",a[j]);
  scanf("%d",k);
  FindKPosition();
  printf("%d %d\n",answerx,answery);
  return 0;
}

前面的题都一样,代码只找到C 有空再把P的代码发上来(其实就语法不一样...)
回复

使用道具 举报

发表于 2008-10-19 15:08 | 显示全部楼层
晕~,不懂啊!很难。
回复

使用道具 举报

发表于 2008-10-19 16:38 | 显示全部楼层
我只参加数理化的,信息学我们学校不注重,不过我觉得信息学好像比数理化简单一些(不要磨刀砍我。。。)
回复

使用道具 举报

 楼主| 发表于 2008-10-19 17:30 | 显示全部楼层
我是参加数学物理和信息的,信息是竞赛里面最简单的,2个月升全国大牛的例子不少见.不过这3科比较要脑些的样子..(0_0)
单选基本都对了,多选也基本对了,问题求解第2问不会看一眼就跳过了.
后面的程序阅读最后一问出BUG应该是4分...
不过我们广西这边分数线很低,基本是过了的.
回复

使用道具 举报

 楼主| 发表于 2008-10-23 17:49 | 显示全部楼层
今年出现重大BUG,普及组分数线36,提高组43,去年提高才29...
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|大科技

GMT+8.8, 2024-12-23 21:20 , Processed in 0.389154 second(s), 15 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表