NOIP初赛知识点
http://www.doc88.com/p-9982181637642.html
连载中……
(一)八大排序算法
下面这张表摘自博客http://blog.csdn.net/whuslei/article/details/6442755/
排序算法基本就考这张表
另1:快排找第k大的数,O(N)
另2:拓扑排序。
拓扑排序对象:有向无环图
拓扑排序方法:
1、首先选出一个入度为0的点
2、将改点输出,然后删除所有与该点相连的边
3、重复步骤1、2,直到输出了n个点
对于上面的那个图,答案是:
通常,一个有向无环图可以有一个或多个拓扑排序序列。
另3:计数排序
计数排序是一个非基于比较的排序算法,该算法于1954年由 Harold H. Seward 提出。它的优势在于在对一定范围内的整数排序时,它的复杂度为Ο(n+k)(其中k是整数的范围),快于任何比较排序算。当然这是一种牺牲空间换取时间的做法,而且当O(k)>O(n*log(n))的时候其效率反而不如基于比较的排序(基于比较的排序的时间复杂度在理论上的下限是O(n*log(n)), 如归并排序,堆排序)
计数排序是稳定的
(二)进制转换
(1)二、四、八、十六互转通用方法:
以八进制转二进制为例
先把关系表列出来:
八进制数 |
二进制数 |
0 |
000 |
1 |
001 |
2 |
010 |
3 |
011 |
4 |
100 |
5 |
101 |
6 |
110 |
7 |
111 |
二转八:
例如:10010011
2^3=8
所以使用三位一合的方法(以小数点为分界)
对照上面的表 10 010 011
2 2 3
八转二:
同理,一位三分法
例如:7643
对照上面的表 7 6 4 3
111 110 100 011
(2) 二转十和十转二
二转十:个位*2^0,十位*2^1,百位*2^2…… 若是小数,十分位*2^-1,百分位*2^-2……然后加起来就行了
十转二:整数转换:短除法,倒取余数
小数转换:整数部分同上,小数部分不断*2,取整数部分,直到乘到1为止
(三)古怪的位运算
与(按位与& 逻辑与∧) 11取1 其它取0
或(按位或| 逻辑或∨) 00取0 其它取1
异或(按位异或^) 一样取0 不一样取1
取反(按位取反~ 逻辑取反﹁或!) 1变0,0变1
优先级:~ > & > ^ > |
位运算:
对于两个数进行按位运算时,先将两个数转化为二进制(小数点对齐),然后将每一位都进行逻辑运算(注意空位补0)
比如,计算21^2
先转换为二进制
21=(10101)2
2=(10)2
然后按位进行逻辑异或运算
10101
^ 10
————
10111
最后得出结果(10111)2=23
逻辑运算:
判断逻辑运算式的真假值时,把数带进去算一下就好了
例:A=true,B=false,C=false,D=true时
(A∧B)∨(C∧D)=0
((A∧B)∨C)∧D=0
A∧((B∨C)∨D)=1
(A∧(B∨C))∨D=1
(A∨B)∧(C∨D)=1
遇到这种题细心计算就好了
(四)集合论
集合就是同一种东西组成的一大坨东西
集合的三个性质:
【1】确定性. 一个元素a是否属于一个集合A,是确定的,不存在既属于,又不属于的关系.
【2】互异性. 同一个集合内,任何两个元素均是不同的.
【3】无序性. 同一个集合内,元素是无序的,即{a,b}与{b,a}是同一个集合.
一些概念:
空集:没用任何元素的集合
子集:若集合A中的所有元素都包含在集合B中,则定义集合A是集合B的子集。符号为A ⊆ B。例如{1,2} 是{1,2,3} 的子集,但{1,4} 就不是{1,2,3} 的子集。依照定义,任一个集合也是本身的子集,不考虑本身的子集称为真子集。
并集:指两个集合所有包含的部分,符号∪。如集合{1,2,3}和集合{2,3,4}的交集为集合{1,2,3,4}。(可以理解为∨)
交集:指两个集合间相同的部分,符号∩。如集合{1,2,3}和集合{2,3,4}的交集为集合{2,3}。(可以理解为∧)
相对差集:指集合A中有但集合B中没有的部分,符号为A \ B,相对差集{1,2,3} \ {2,3,4} 为{1}。注意:这玩意是单向的,即A\B和B\A是不同的。
对称差:指只在集合A及B中的其中一个出现,没有在其交集中出现的元素。符号为A △ B或A⊕B或A——B,例如集合{1,2,3} 和{2,3,4} 的对称差为{1,4}。
如果上面的看不太懂,可以看看下面的图(摘自百度百科):
针对这张图:
左上:并集,A ∪ B;
右上:交集,A ∩ B;
左下:A对于B的相对差集,A \ B;
右下:对称差,A △ B或A⊕B或A——B;
来道例题:
设全集I={a,b,c,d,e,f,g},集合A={a,b,c},B={b,d,e},C={e,f,g},那么集合A{a,b,c,d}B{a,b,d,e}C{b,d,e}合(A—B)∪(~C∩B)为()。
A.{a,b,c,d} B.{a,b,d,e} C.{b,d,e} D.{b,c,d,e} E.{d,f,g}
解:A——B为A中的“月牙”,即为ac;~C为abcd,再取和B的并集为bd,然后再取并集abcd。
所以答案为A
注意:注意优先级!!!~优先于∩优先于∪
(五)二叉树
定义:
n个结点的有限集,每个结点至多只有两棵子树,子树也是二叉树。每个结点可以有左孩子和右孩子,顺序不可颠倒。
概念:
度:某个结点孩子的个数
叶子:度为0的结点
深度:二叉树的层数
满二叉树:深度为
n且结点数为2n-1的二叉树
完全二叉树:深度为k,1~k-1层为满二叉树,第k层叶子节点集中在左边的二
n个结点所组成的不同形态的二叉树数目为:C(2n,n)/(n+1)
(六)指针
*是指针,取地址
&是取址符,取地址里的值
int *a; //a是地址中的值
b=&c; //b是地址
(七)基本常识
一个字节(byte)由八个二进制位组成
8bit=1byte
完全图:所有顶点之间两两有一条无向边
通讯标准:
1、模拟
2、GCM
3、WCDMA
4、FDD-LTE
5、华为
(八)数论
n^(-m)=1/(n^m)
(九)表达式
先建树
(十)问题求解
1、要耐心地寻找规律
2、要冷静的分析问题
3、不到万不得已决不轻言放弃
4、不懂就蒙一个!
(十一)阅读程序
1、认真计算
2、耐心分析
3、分析不下去就函数(语句作用)
4、千万记得第一个阅读程序要检查
5、多多练习,熟能生巧
6、列出变量变化表
(十二)程序填空
这种题与编程经验和算法学习的程度有关,拿得一分是一分。
~祝大家NOIP取得好成绩~
(完结撒花)
【鼓掌】【啪啪啪】【鼓掌】
NOIP初赛知识点的更多相关文章
- NOIP初赛知识点大全-普及+提高组
NOIP初赛知识点大全-普及+提高组 https://mp.weixin.qq.com/s/vSXLDxmbBoFfZPzD8lrt3w
- 史上最全NOIP初赛知识点
CSP-J/S 第一轮知识点选讲 \(NOIP\)(全国青少年信息学奥林匹克竞赛)于2019年取消.取而代之的是由\(CCF\)推出的非专业级软件能力认证,也就是现在的\(CSP-J/S\).作为一名 ...
- NOIp初赛题目整理
NOIp初赛题目整理 这个 blog 用来整理扶苏准备第一轮 csp 时所做的与 csp 没 有 关 系 的历年 noip-J/S 初赛题目,记录了一些我从不知道的细碎知识点,还有一些憨憨题目,不定期 ...
- NOIP初赛 之 逻辑运算
NOIP初赛 之 逻辑运算 逻辑运算先掌握各种运算,注意运算符的级别比较,做题是要细心.在NOIP中一般一题,分值为1.5分. 概念介绍: 非:not ¬ 与:and ∧ 或:o ...
- NOIP初赛:完善程序做题技巧
最近写的文章好像还很多的.那么今天我们来讨论NOIP初赛的题型--完善程序.完善程序相对是比较难的题目了.全卷100分,完善程序占了大概26分,占比非常大.如果和英语考试试卷做比较,相当于首字母填空( ...
- noip 初赛复习重点知识点
一.进制转化 将k进制数转化为十进制数: 设k进制数为(abcd)k,则对应十进制数为 (小数同理,乘k的负幂次) 将十进制数转成k进制数: 设十进制数为x: t1=x/k,t2=x mod k t1 ...
- NOIP初赛前一日记
2018年10月12日,早晨7:25于机房. 早晨的鄞中,晨风还有点清冷.看着电脑上翻遍的资料,心里实在是有一种说不出的感觉. 说出来也算是丢脸——作为浙江选手,我为了NOIP2018的初赛,停课了一 ...
- NOIP2018提高组初赛知识点
(传说,在神秘的初赛中,选手们经常互相爆零以示友好……) 历年真题:ti.luogu.com.cn 以下标题中打*的是我认为的重点内容 一.关于计算机 (一)计算机组成 硬件组成: 1. 控制器(C ...
- 【OI新闻】2016.10.26 - NOIP初赛泄题再次引爆
有点劲,开车注意点,小心翻啦~ http://www.noi.cn/noi-news/noi/743-ccfnoip2016 CCF在NOIP2016初赛结束后接到举报:初赛前(22日12时左右),网 ...
随机推荐
- unable to locate package gparted
在unbuntu安装gparted的时候出现这个错误提示,意思为:找不到这个安装包 可能的原因: 1.当前系统更新包没有更新,执行命令:sudo apt-get update 2.命令错误,重新检查需 ...
- 在Android Studio中查看Sqlite的方法
只说最好的方法,使用工具stetho:http://facebook.github.io/stetho/ 1.在Gragle中加上如下语句: dependencies { // Stetho core ...
- 网络编程 -- RPC实现原理 -- RPC -- 迭代版本V3 -- 远程方法调用 整合 Spring
网络编程 -- RPC实现原理 -- 目录 啦啦啦 V3——RPC -- 远程方法调用 及 null的传输 + Spring 服务提供商: 1. 配置 rpc03_server.xml 注入 服务提供 ...
- python数据类型之字典(二)
字典的基本操作 键值查找: >>> aInfo = {'Wangdachui':3000,'Niuyun':2000,'Linling':4500,'Tianqi':8000} &g ...
- Struts2常用标签总结(申明:来源于网络)
Struts2常用标签总结(申明:来源于网络) 地址:http://jimingsong.iteye.com/blog/1582939
- Glusterfs挂载报错解决办法
环境查看 挂载glusterfs时候报错 下载软件(Redhat没有注册无法直接yum安装) https://buildlogs.centos.org/centos/6/storage/x86_64/ ...
- 洛谷 P1208混合牛奶【贪心】
题目描述 由于乳制品产业利润很低,所以降低原材料(牛奶)价格就变得十分重要.帮助Marry乳业找到最优的牛奶采购方案. Marry乳业从一些奶农手中采购牛奶,并且每一位奶农为乳制品加工企业提供的价格是 ...
- 文末有福利 | IT从业者应关注哪些技术热点?
7月14-15日,MPD工作坊北京站即将开幕,目前大会日程已经出炉,来自各大企业的技术专家,按照软件研发中心的岗位职能划分,从产品运营.团队管理.架构技术.自动化运维等领域进行干货分享,点击此[链接] ...
- css学习_css背景属性及其应用
css背景属性及其应用 1.背景 2.背景简写 3.背景透明(css3) 4.背景缩放(css3) 5.多背景图片(css3) 6.凹凸文字效果
- {python之协程}一 引子 二 协程介绍 三 Greenlet 四 Gevent介绍 五 Gevent之同步与异步 六 Gevent之应用举例一 七 Gevent之应用举例二
python之协程 阅读目录 一 引子 二 协程介绍 三 Greenlet 四 Gevent介绍 五 Gevent之同步与异步 六 Gevent之应用举例一 七 Gevent之应用举例二 一 引子 本 ...