IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 2016第二十二届全国青少年信息学奥林匹克联赛初赛 -> 正文阅读

[C++知识库]2016第二十二届全国青少年信息学奥林匹克联赛初赛

一、单项选择题(共?20?题,?每题?1.5?分,?共计?30?分;?每题有且仅有一个正确选?项)

1.????以下不是微软公司出品的软件是? D?

A.????Powerpoint

C.????Excel

B.????Word

D.????Acrobat?Reader

Adobe是著名的软件公司,拥有photoshop,acrobat,audition等软件。

2.????如果?256?种颜色用二进制编码来表示,至少需要? C?位。

A.????6????????????????????????????B.????7????????????????????????????C.????8???????????????????????????D.????9

本题考查二进制的基本知识。256=2*2*2*2*2*2*2*2,故需要至少8位编码。

3.????以下不属于无线通信技术的是?D??

A.????蓝牙?????????B.????WiFi??????????????????????C.????GPRS????????????????????D.????以太网

以太网使用的是有线连接。

4.????以下不是?CPU?生产厂商的是? C?

A.????Intel??????????????????????B.????AMD?????????????????????C.????Microsoft????????????D.????IBM

Microsoft属于软件公司,没有硬件产品,IBM软硬件都生产。

5.????以下不是存储设备的是?D??

A.????光盘?????????B.????磁盘?????????C.????固态硬盘?????D.????鼠标

鼠标属于输入设备。

6.????如果开始时计算机处于小写输入状态,现在有一只小老鼠反复按照CapsLock?字母键?A、字母键?S?和字母键?D?的顺序循环按键,即?CapsLock?A?S?D???CapsLock?A?S?D?、……,屏幕上输出的第?81?个字符是字母?C??

A.????A???????????????????????????B.????S????????????????????????????C.????D???????????????????????????D.????a

输出的字符以“ASDasd” 为循环,81%6=3,故应该为第三个字符,即大写字母D。

7.????二进制数?00101100??00010101?的和是? B?

A.????00101000????????????B.????01000001????????????C.????01000100????????????D.????00111000

二进制加法。逢二进一

8.????与二进制小数?0.1?相等的八进制数是???

A.????0.8????????????????????????B.????0.4????????????????????????C.????0.2????????????????????????D.????0.1

9.????以下是?32?位机器和?64?位机器的区别的是?C??

A.????显示器不同

C.????寻址空间不同

B.????硬盘大小不同

D.????输入法不同

32位、64位指的是地址总线的位数

10.??以下关于字符串的判定语句中正确的是? A?

A.????字符串是一种特殊的线性表

C.????字符串不可以用数组来表示

B.????串的长度必须大于零

D.????空格字符组成的串就是空串

本题采用排除法。字符串允许是长度为0的空串,排除B;字符数组也可以字符串功能,排除C;

空串指的是不包含任何字符,长度为0的字符串,因此排除D。

11.??一棵二叉树如右图所示,若采用顺序存储结构,即用一?维数组元素存储该二叉树中的结点(根结点的下标为?1?若某结点的下标为?i?,则其左孩子位于下标?2i?处、右孩?子位于下标(2i+1)?则图中所有结点的最大下标为(? D )。

A.????6????????????????????????????B.????10?????????????????????????C.????12? ? ? ? ? ? ? ? ? ??D.????15

下标最大的节点为最下最右的节点。2的4次方减1=15。

12.??若有如下程序段,其中s?a?b?c?均已定义为整型变量,且a?c?均已赋值?c?大于?0)。

s?=?a;

for?(b?=?1;?b?<=?c;?b++)

s?=?s?+?1;

则与上述程序段修改?s?值的功能等价的赋值语句是??B?

A.????s?=?a?+?b;??B.????s?=?a?+?c;??C.????s?=?s?+c;??D.????s?=?b?+?c;

循环语句执行c次加1,就是求a和c的和。

13.??有以下程序:

#include?<iostream>
using?namespace?std;
int?main()?{
int?k?=?4,?n?=?0;
while?(n?<?k)?{????
    n++;????????????
    if?(n?%?3?!=?0)
    continue;
    k--;
}
 cout?<<?k?<<?","?<<?n?<<?endl;
 return?0;
}

程序运行后的输出结果是?D??

A.????2,2????????????????????????B.????2,3????????????????????????C.????3,2????????????????????????D.????3,3

continue语句的作用是跳过当前循环体未执行的语句(k--),而继续执行下次循环。因此只有在

n=3时才会执行k--使得k=3,并终止循环。

14.??给定含有?n?个不同的数的数组?L=<x1,?x2,?...,?xn>。如果?L?中存在?xi1?<?i?<?n?使得?x1?<?x2?<?...?<?xi-?1?<?xi?>?xi+1?>?...?>?xn??则称?L?是单峰的,并称?xi??L?

“峰顶”。现在已知?L?是单峰的,请把?a-c?三行代码补全到算法中使得算法?正确找到?L?的峰顶。

a.?Search(k+1,?n)

b.?Search(1,?k-1)

c.?return?L[k]

Search(1,?n)

1.?k←?n/2?

2.?if?L[k]?>?L[k-1]?and?L[k]

3.?then?__________

4.?else?if?L[k]?>?L[k-1]?and

5.?then?__________

6.?else?__________

正确的填空顺序是???

A.????c,?a,?b???????????????????B.????c,?b,?a

>?L[k+1]

L[k]?<?L[k+1]

C.????a,?b,?c???????????????????D.????b,?a,?c

15.??设简单无向图?G??16?条边且每个顶点的度数都是?2,则图?G????个顶

A.????10??????????????????????????B.????12?????????????????????????C.????8???????????????????????????D.????16

16.???7?个一模一样的苹果,放到?3?个一样的盘子中,一共有???种放法。

A.????7????????????????????????????B.????8????????????????????????????C.????21?????????????????????????D.????37

17.??下图表示一个果园灌溉系统,??ABCD?四个阀门,?每个阀门可以打开

或关上,?所有管道粗细相同,?以下设置阀门的方法中,?可以让果树浇上水的

果树

???

A.????B?打开,其他都关上

C.????A?打开,其他都关上

B.????AB?都打开,?CD?都关上

D.????D?打开,其他都关上

18.??Lucia?和她的朋友以及朋友的朋友都在某社交网站上注册了账号。下图是他?们之间的关系图,?两个人之间有边相连代表这两个人是朋友,?没有边相连代?表不是朋友。这个社交网站的规则是:如果某人?A?向他(她)的朋友?B???享了某张照片,?那么?B?就可以对该照片进行评论;?如果?B?评论了该照片,??么他(她)?的所有朋友都可以看见这个评论以及被评论的照片,?但是不能对?该照片进行评论(除非?A?也向他(她)?分享了该照片)?。现在?Lucia?已经上?传了一张照片,但是她不想让?Jacob?看见这张照片,?那么她可以向以下朋友????分享该照片。

A.????Dana,?Michael,?Eve

C.????Michael,?Eve,?Jacob

B.????Dana,?Eve,?Monica

D.????Micheal,?Peter,?Monica

19.??周末小明和爸爸妈妈三个人一起想动手做三道菜。小明负责洗菜、爸爸负责??切菜、妈妈负责炒菜。假设做每道菜的顺序都是:先洗菜?10?分钟,?然后切????10?分钟,最后炒菜?10?分钟。那么做一道菜需要?30?分钟。注意:两道不???同的菜的相同步骤不可以同时进行。例如第一道菜和第二道的菜不能同时洗,?也不能同时切。那么做完三道菜的最短时间需要???分钟。

A.????90??????????????????????????B.????60?????????????????????????C.????50?????????????????????????D.????40

20.??参加?NOI?比赛,以下不能带入考场的是?C??

A.????钢笔?????????B.????适量的衣服???C.????U??????????D.????铅笔

U盘是可以存储信息的设备,不需要也不允许选手带入考场。

二、?问题求解(共?2?题,?每题?5?分,?共计?10?分;第一题全部答对得?5?分,?没有?部分分;第二题第一空?2?分,?第二空?3?分)

1.????从一个?4×4?的棋盘(不可旋转)?中选取不在同一行也不在同一列上的两个?方格,共有??????????种方法。

2.????约定二叉树的根节点高度为?1。一棵结点数为?2016?的二叉树最少有????个叶子结点;?一棵结点数为?2016?的二叉树最小的高度值是

三、阅读程序写结果(共?4?题,?每题?8?分,?共计?32?分)

1.????#include?<iostream>??using?namespace?std;

int?main()?{

int?max,?min,?sum,?count?=?0;

int?tmp;

cin?>>?tmp;

if?(tmp?==?0)

return?0;

max?=?min?=?sum?=?tmp;

count++;

while?(tmp?!=?0)?{

cin?>>?tmp;

if?(tmp?!=?0)?{

sum?+=?tmp;

count++;

if?(tmp?>?max)

max?=?tmp;

if?(tmp?<?min)

min?=?tmp;

}

}

cout?<<?max?<<?","?<<?min?<<?","?<<?sum?/?count?<<?endl;?return?0;

}

输入:?1?2?3?4?5?6?0?7

输出:?_________

2.????#include?<iostream>??using?namespace?std;

int?main()?{

int?i?=?100,?x?=?0,?y?=?0;

while?(i?>?0)?{

i--;

x?=?i?%?8;

if?(x?==?1)

y++;

}

cout?<<?y?<<?endl;

return?0;

}

输出:?_________

3.????#include?<iostream>??using?namespace?std;

int?main()?{

int?a[6]?=?{1,?2,?3,?4,?5,?6};

int?pi?=?0;

int?pj?=?5;

int?t?,?i;

while?(pi?<?pj)?{

t?=?a[pi];

a[pi]?=?a[pj];

a[pj]?=?t;

pi++;

pj--;

}

for?(i?=?0;?i?<?6;?i++)

cout?<<?a[i]?<<?",";

cout?<<?endl;

return?0;

}

输出:?_________

4.????#include?<iostream>??using?namespace?std;

int?main()?{

int?i,?length1,?length2;

string?s1,?s2;

s1?=?"I?have?a?dream.";

CCF NOIP2016?初赛普及组?C++语言试题

?6????9?

s2?=?"I?Have?A?Dream.";

length1?=?s1.size();

length2?=?s2.size();

for?(i?=?0;?i?<?length1;?i++)

if?(s1[i]?>=?'a'?&&?s1[i]?<=?'z')

s1[i]?-=?'a'?-?'A';

for?(i?=?0;?i?<?length2;?i++)

if?(s2[i]?>=?'a'?&&?s2[i]?<=?'z')

s2[i]?-=?'a'?-?'A';

if?(s1?==?s2)

cout?<<?"="?<<?endl;

else?if?(s1?>?s2)

cout?<<?">"?<<?endl;

else

cout?<<?"<"?<<?endl;

return?0;

}

输出:?_________

四、完善程序(共?2?题,每题?14?分,?共计?28?分)

1.???(读入整数)请完善下面的程序,?使得程序能够读入两个?int?范围内的整数,

并将这两个整数分别输出,每行一个。(第一、五空?2.5?分,其余?3?分)?输入的整数之间和前后只会出现空格或者回车。?输入数据保证合法。

例如:?输入:

输出:

#include

123????-789

123

-789

<iostream>

using?namespace?std;

int?readint()?{

int?num?=?0;

int?negative?=?0;?char?c;

c?=?cin.get();

while?((c?<?'0'?||?c?=????(1)???;

//?存储读取到的整数

//?负数标识

//?存储当前读取到的字符

c?>?'9')?&&?c?!=?'-')

if?(c?==?'-')

negative?=?1;

else

(2)???;

c?=?cin.get();

while?(???(3)???)?{

(4)???;

c?=?cin.get();

}

if?(negative?==?1)

(5)???;

return?num;

}

int?main()?{

int?a,?b;

a?=?readint();

b?=?readint();

cout?<<?a?<<?endl?<<?b?<<?endl;

return?0;

}

2.???(郊游活动)??n?名同学参加学校组织的郊游活动,?已知学校给这?n?名同学?的郊游总经费为?A?元,与此同时第?i?位同学自己携带了?Mi?元。为了方便郊?游,?活动地点提供?B(n)辆自行车供人租用,?租用第j?辆自行车的价格为?Cj?元,?每位同学可以使用自己携带的钱或者学校的郊游经费,?为了方便账务管?理,?每位同学只能为自己租用自行车,?且不会借钱给他人,?他们想知道最多?有多少位同学能够租用到自行车。?(第四、五空?2.5?分,其余?3?分)

本题采用二分法。对于区间[l,?r]?,我们取中间点?mid?并判断租用到自行?车的人数能否达到mid。判断的过程是利用贪心算法实现的。

#include?<iostream>

using?namespace?std;

#define?MAXN?1000000

int?n,?B,?A,?M[MAXN],?C[MAXN],?l,?r,?ans,?mid;

bool?check(int?nn)?{

int?count?=?0,?i,?j;

i?=????(1)???;

j?=?1;

while?(i?<=?n)?{

if?(???(2)???)

count?+=?C[j]?-?M[i];

i++;

j++;

}

return????(3)???;

}

void?sort(int?a[],?int?l,?int?r)?{

int?i?=?l,?j?=?r,?x?=?a[(l?+?r)?/?2],?y;

while?(i?<=?j)?{

while?(a[i]?<?x)?i++;

while?(a[j]?>?x)?j--;

if?(i?<=?j)?{

y?=?a[i];?a[i]?=?a[j];?a[j]?=?y;

i++;?j--;

}

}

if?(i?<?r)?sort(a,?i,?r);

if?(l?<?j)?sort(a,?l,?j);

}

int?main()?{

int?i;

cin?>>?n?>>?B?>>?A;

for?(i?=?1;?i?<=?n;?i++)

cin?>>?M[i];

for?(i?=?1;?i?<=?B;?i++)

cin?>>?C[i];

sort(M,?1,?n);

sort(C,?1,?B);

l?=?0;

r?=?n;

while?(l?<=?r)?{

mid?=?(l?+?r)?/?2;

if?(???(4)???)?{

ans?=?mid;

l?=?mid?+?1;

}?else

r?=????(5)???;

}

cout?<<?ans?<<?endl;

return?0;

}

https://open-data-api.csdn.net/api/v1/61b17c289e6cb947db56bae5/c/ipicon-default.png?t=M276https://open-data-api.csdn.net/api/v1/61b17c289e6cb947db56bae5/c/ip

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-21 20:30:29  更:2022-03-21 20:33:55 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 16:21:27-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码