| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> C++知识库 -> 2018年的noip普及组题目+答案,复赛 -> 正文阅读 |
|
[C++知识库]2018年的noip普及组题目+答案,复赛 |
1.标题统计 题目描述
查看题目信息
凯凯刚写了一篇美妙的作文,请问这篇作文的标题中有多少个字符? 注意:标题中可能包含大、小写英文字母、数字字符、空格和换行符。统计标题字符数时,空格和换行符不计算在内。 输入格式输入文件只有一行,一个字符串s。 输出格式输出文件只有一行,包含一个整数,即作文标题的字符数(不含空格和换行符)。 样例输入234
样例输出3
样例输入Ca 45
样例输出4
问题提示【输入输出样例1说明】 标题中共有3个字符,这3个字符都是数字字符。 【输入输出样例2说明】 标题中共有5个字符,包括1个大写英文字母,1个小写英文字母和2个数字字符,还有1个空格。由于空格不计入结果中,故标题的有效字符数为4个。 【数据规模与约定】 规定?|s|?表示字符串s的长度(即字符串中的字符和空格数)。 对于40%?的数据,1?≤|s|≤?5,保证输入为数字字符及行末换行符。 对于80%?的数据,1≤|s|≤5,输入只可能包含大、小写英文字母、数字字符及行末换行符。 对于100%?的数据,1≤|s|≤5,输入可能包含大、小写英文字母、数字字符、空格和行末换行符。 #include <cstdio> 2.龙虎斗 题目描述
查看题目信息
轩轩和凯凯正在玩一款叫《龙虎斗》的游戏,游戏的棋盘是一条线段,线段上有n个兵营(自左至右编号1~n),相邻编号的兵营之间相隔1厘米,即棋盘为长度为n?1厘米的线段。i号兵营里有ci位工兵。 下面图1为?n=6?的示例: 图1. n=6的示例 轩轩在左侧,代表“龙”;凯凯在右侧,代表“虎”。他们以m号兵营作为分界,靠左的工兵属于龙势力,靠右的工兵属于虎势力,而第m号兵营中的工兵很纠结,他们不属于任何一方。 一个兵营的气势为:该兵营中的工兵数??该兵营到m号兵营的距离;参与游戏一方的势力定义为:属于这一方所有兵营的气势之和。 下面图2为?n=6,m=4?的示例,其中红色为龙方,黄色为虎方: ?n=6,m=4的示例 游戏过程中,某一刻天降神兵,共有s1位工兵突然出现在了p1号兵营。作为轩轩和凯凯的朋友,你知道如果龙虎双方气势差距太悬殊,轩轩和凯凯就不愿意继续玩下去了。为了让游戏继续,你需要选择一个兵营p2,并将你手里的s2位工兵全部派往兵营p2,使得双方气势差距尽可能小。 注意:你手中的工兵落在哪个兵营,就和该兵营中其他工兵有相同的势力归属(如果落在m号兵营,则不属于任何势力)。 输入格式输入文件名为fight.in。 输入文件的第一行包含一个正整数n,代表兵营的数量。 接下来的一行包含n个正整数,相邻两数之间以一个空格分隔,第i个正整数代表编号为�?的兵营中起始时的工兵数量ci。 接下来的一行包含四个正整数,相邻两数间以一个空格分隔,分别代表m,p1,s1,s2。 输出格式输出文件名为fight.out 输出文件有一行,包含一个正整数,即p2,表示你选择的兵营编号。如果存在多个编号同时满足最优,取最小的编号。 样例输入6
2 3 2 3 2 3
4 6 5 2
样例输出2
样例输入6
1 1 1 1 1 16
5 4 1 1
样例输出1
问题提示【输入输出样例1说明】 见问题描述中的图2。 双方以?m=4?号兵营分界,有s1=5?位工兵突然出现在?p1=6?号兵营。 【输入输出样例2说明】 双方以?m=5?号兵营分界,有s1=1?位工兵突然出现在?p1=4?号兵营。 此时可以使双方气势的差距最小。 【数据规模与约定】 1<m<n,1≤p1≤n。 对于20%?的数据,n=3,m=2,ci=1,s1,s2≤100。 另有20%?的数据,n≤10,p1=m,ci=1,s1,s2≤100。 对于60%?的数据,n≤100,ci=1,s1,s2≤100。 对于80%?的数据,n≤100,ci,s1,s2≤100。 对于100%?的数据,n≤105,ci,s1,s2≤109。 #include <bits/stdc++.h> int n, m, p1, p2; int main() { 3.摆渡车 题目描述
查看题目信息
有n名同学要乘坐摆渡车从人大附中前往人民大学,第i位同学在第ti分钟去等车。只有一辆摆渡车在工作,但摆渡车容量可以视为无限大。摆渡车从人大附中出发、把车上的同学送到人民大学、再回到人大附中(去接其他同学),这样往返一趟总共花费m分钟(同学上下车时间忽略不计)。摆渡车要将所有同学都送到人民大学。 凯凯很好奇,如果他能任意安排摆渡车出发的时间,那么这些同学的等车时间之和最小为多少呢? 注意:摆渡车回到人大附中后可以即刻出发。 输入格式第一行包含两个正整数n、m,以一个空格分开,分别代表等车人数和摆渡车往返一趟的时间。 第二行包含n个正整数,相邻两数之间以一个空格分隔,第i个非负整数ti代表第i个同学到达车站的时刻。 输出格式输出一行,一个整数,表示所有同学等车时间之和的最小值(单位:分钟)。 样例输入5 1
3 4 4 3 5
样例输出0
样例输入5 5
11 13 1 5 5
样例输出4
问题提示【输入输出样例1说明】 同学1和同学4在第3分钟开始等车,等待0分钟,在第3分钟乘坐摆渡车出发。摆渡车在第4分钟回到人大附中。 同学2和同学3在第4分钟开始等车,等待0分钟,在第4分钟乘坐摆渡车出发。摆渡车在第5分钟回到人大附中。 同学5在第5分钟开始等车,等待0分钟,在第5分钟乘坐摆渡车出发。自此所有同学都被送到人民大学。总等待时间为0。 【输入输出样例2说明】 同学3在第1分钟开始等车,等待0分钟,在第1分钟乘坐摆渡车出发。摆渡车在第6分钟回到人大附中。 同学4和同学5在第5分钟开始等车,等待1分钟,在第6分钟乘坐摆渡车出发。摆渡车在第11分钟回到人大附中。 同学1在第11分钟开始等车,等待2分钟;同学2在第13分钟开始等车,等待0分钟。他/她们在第13分钟乘坐摆渡车出发。自此所有同学都被送到人民大学。总等待时间为4。可以证明,没有总等待时间小于4的方案。 【数据规模与约定】 对于10%?的数据,n≤10,?m=1,?0≤ti≤100。 对于30%?的数据,n≤120,?m≤2,?0≤ti≤100。 对于50%?的数据,n≤500,?m≤100,?0≤ti≤104。 另有20%?的数据,n≤500,?m≤10,?0≤ti≤4×106。 对于100%?的数据,n≤500,?m≤100,?0≤ti≤4×106。 #include <bits/stdc++.h> int n, m, t, maxt; int main() { 4.对称二叉树 题目描述
查看题目信息
一棵有点权的有根树如果满足以下条件,则被轩轩称为对称二叉树: 1.?二叉树; 2.?将这棵树所有节点的左右子树交换,新树和原树对应位置的结构相同且点权相等。 下图中节点内的数字为权值,节点外的?id表示节点编号。 现在给出一棵二叉树,希望你找出它的一棵子树,该子树为对称二叉树,且节点数最多。请输出这棵子树的节点数。 注意:只有树根的树也是对称二叉树。本题中约定,以节点?TT?为子树根的一棵“子?树”指的是:节点T和它的全部后代节点构成的二叉树。 输入格式第一行一个正整数n,表示给定的树的节点的数目,规定节点编号1n,其中节点1是树根。 第二行n个正整数,用一个空格分隔,第?i个正整数vi?代表节点i的权值。 接下来n行,每行两个正整数li, ri??,分别表示节点i的左右孩子的编号。如果不存在左/右孩子,则以?-1表示。两个数之间用一个空格隔开。 输出格式输出文件共一行,包含一个整数,表示给定的树的最大对称二叉子树的节点数。 样例输入2
1 3
2 -1
-1 -1
样例输出1
样例输入10
2 2 5 5 5 5 4 4 2 3
9 10
-1 -1
-1 -1
-1 -1
-1 -1
-1 2
3 4
5 6
-1 -1
7 8
样例输出3
问题提示【输入输出样例1说明】 最大的对称二叉子树为以节点2?为树根的子树,节点数为1。 【输入输出样例2说明】 最大的对称二叉子树为以节点7?为树根的子树,节点数为3。 【数据规模与约定】 共25个测试点。 vi?≤?1000。 测试点1~3,n≤10,保证根结点的左子树的所有节点都没有右孩子,根结点的右子树的所有节点都没有左孩子。 测试点4~8,n≤10。 测试点9~12,n≤105,保证输入是一棵“满二叉树”。 测试点13~16,n≤105,保证输入是一棵“完全二叉树”。 测试点17~20,n≤105,保证输入的树的点权均为1。 测试点21~25,n≤106。 本题约定: 层次:节点的层次从根开始定义起,根为第一层,根的孩子为第二层。树中任一节点的层次等于其父亲节点的层次加1。 树的深度:树中节点的最大层次称为树的深度。 满二叉树:设二叉树的深度为h,且二叉树有2h-1个节点,这就是满二叉树。 #include<cstdio> inline int max(int x, int y) const int MAXN = 1000000; // 检查左右子树是否对称 ?? ?if(v[leftId] != v[rightId]) // 求第nodeId个节点为根节点的二叉树,所包含的节点总数 void dfs(int nodeId) ? ? // 左子树节点总数 等于 右子树节点总数,这是对称的前提 ? ? // 左子树下是否包含对称二叉树 int main() ?? ?int n; ?? ?nodeCnt(1); ?? ?return 0; 点赞关注!!! + ?=======================?? ?happy !!! ? ? |
|
C++知识库 最新文章 |
【C++】友元、嵌套类、异常、RTTI、类型转换 |
通讯录的思路与实现(C语言) |
C++PrimerPlus 第七章 函数-C++的编程模块( |
Problem C: 算法9-9~9-12:平衡二叉树的基本 |
MSVC C++ UTF-8编程 |
C++进阶 多态原理 |
简单string类c++实现 |
我的年度总结 |
【C语言】以深厚地基筑伟岸高楼-基础篇(六 |
c语言常见错误合集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/23 20:26:14- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |