自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(24)
  • 资源 (1)
  • 收藏
  • 关注

原创 2021-03-23

CCF-CSP 字符画这题只得了80分,还没有搞明白哪里出问题。这题思路其实很清晰的,先把输入的矩阵的元素解析成RGB三元组并以二维数组保存起来,然后按照要求,分块求平均值,注意这里的平均值是三种颜色各自的平均值。求出平均值后存到一个新的二维数组。然后按照给定的规则来绘制,具体规则我这里就不展开了,对每一个像素(即RGB三元组)输出一个空格,并且可能带有变色控制指令。注意题目提到了前景色和背景色,但是其实用到的只有背景色。对于最后输出为字符的16进制格式的处理上,我取了个巧:先按照字符串的形式保存起来,

2021-03-23 20:39:13 84

原创 2021-03-19

CCF-CSP MarkdownCCF考Markdown的题目好像不是第一次了,而且HTML相关的也考过。这题把Markdown语法和HTML输出结合起来,要求解析Markdown语法(部分),然后转换为HTML输出。分为区块和行内两种语法,其中区块是空行分隔的,所以就很好处理了,因为一个区块内没有空行,并且相邻区块之间必定有空行,所以处理一个区块时,读取连续的非空行即可。当然保险起见,如果区块的行有某些特征,比如列表的行以星号开头,那么可以读取连续的有特征的行。于是程序主体分为两层,外层枚举所有区块,

2021-03-19 10:00:51 79

原创 2021-03-18

CCF-CSP Crontab非常坑的一题,可能是因为我菜吧。考的的东西很多,把几种模拟题都揉在一起了,比如:日期处理,包括枚举分钟,计算某天是星期几,后者可以枚举天,也有公式,但是我记不住,哈哈。字符串解析,这个不用说了,大模拟必考。解析后建立满足题目意思的数据结构。思路:首先注意日期的表示法,我用的是年月日时分表示法,而不是弄成一个整数,实际上我只会这一种表示法,并且在算法笔记上学过练过。然后把控制表(即Crontab)输入,解析,建立可以方便的查询的数据结构。还是老办法,用enum标记

2021-03-18 22:12:23 89

原创 2021-03-18

CCF-CSP 化学方程式提醒:下面的代码在Dev(C++)模式下编译出错,但是我真的看不出来哪里不对,并且本地用同样的标准编译没问题;而用PAT的OJ编译也是没问题的。所以我用CCF的C++11模式去提交,就100了。很奇怪吧?如果有热心人看出了我哪里有问题,欢迎评论告诉我,谢谢!思路:是CCF的一贯风格:字符串解析。这题我感觉比JSON查询的难度大,因为这题要找出用栈保存什么还是挺难的。虽然出栈和入栈时机很明显,就是碰到左右括号嘛。最后发现原来需要用栈保存当前列表的化学元素的计数(用一个map表示)

2021-03-18 18:20:47 94

原创 2021-03-18

CCF-CSP JSON解析基本思路是用栈解决嵌套对象问题。注意在解析中维护好不变式。这里我用了一种简化的思路:把一个对象看做是一些键值对的序列,然后套用一个经典的解析循环:先跳过分隔符直到找到键值对的开头,然后解析这个键值对,如此循环直到到达字符串结束,或者遇到结束符号。在这里要注意几点:解析键值对时,遇到值为OBJ的,要把当前对象入栈,并令当前对象指向新生成的对象。当遇到对象结束符号,即}时,要把栈顶对象出栈,并把当前对象指向它。如果不存在栈顶对象,说明最顶层对象的解析结束了,应该返回。还有注

2021-03-18 16:14:18 72

原创 2021-03-18

CCF-CSP URL映射把题目的意思先搞懂。就是给你一些URL规则和一些URL,然后对每个URL,按照先后顺序逐个匹配所有URL规则,按照第一个匹配就匹配的原则。匹配成功则输出规则的名字和所有的参数(就是把参数的值从URL里抠出来);匹配失败则输出404 。注意处理结尾的斜杠。因为保证以斜杠开头(规则或者ULR都是如此),所以把URL抽象为片段的序列,每个片段前面必有一个斜杠,只需记录整个串是否以斜杠结尾即可。注意题目的规定,如果最后一个片段是path,则不能以斜杠结尾。最后注意一下规则可能没有片段

2021-03-18 12:21:06 95

原创 2021-02-27

CCF-CSP\专题\题型A 简单模拟\201703-2 学生排队这题考察顺序表的查找和插入操作,基本上就是找到一个元素然后把它插入到前面或者后面的位置,然后保持其他元素的相对位置不变。#include <cstdio>#include <vector>#include <algorithm> // findusing namespace std; /* run this program using the console pauser or add yo

2021-02-27 10:58:23 51

原创 2021-02-27

CCF-CSP\专题\题型A 简单模拟\201709-2 公共钥匙盒这道题难点是怎么处理归还和接走钥匙的逻辑,以及怎么处理时间。其实这里的时间(包括其他CCF的时间)都是离散的,就是可列的,于是用一个数组保存所有的操作,再按照要求去排序,然后按照顺序去模拟即可。排序是个好东西。#include <cstdio>#include <algorithm>using namespace std;/* run this program using the console paus

2021-02-27 10:39:22 67

原创 2021-02-26

CCF-CSP\专题\题型A 简单模拟\201903-2 二十四点简单的中缀表达式计算,无括号,数字是0-9的数字,加减乘除四则运算。注意不需要先转后缀再计算,直接遍历(带栈)就可以计算了。#include <cstdio>#include <stack>using namespace std;int N;const int Len=7;int Ord(char c) { switch (c) { case '-': case '+': retu

2021-02-26 20:09:30 142

原创 2021-02-26

CCF-CSP\专题\题型A 简单模拟\201612-2 工资计算算是比较复杂的简单模拟了,主要难点在于税后工资的计算,因为情况太多,开了一个数组保存税率和下界,然后注意枚举每个税率不同的区间(当然是按税率从低到高枚举),如果当前区间的上界小于等于税前工资A,就扣除当前区间对应的税,否则退出循环,把逻辑搞清楚就行。然后坑点还有保证税前工资是整百。如果用线性查找(也能过,真的!),就每次递增100,如果用二分查找,就注意要对整百进行查找,即用1代表100,2代表200等等,否则当二分除以二的时候,就会有问

2021-02-26 20:06:28 46

原创 2021-02-20

北航机试 2017 查找家族成员输入若干行(总行数不超过),每一行的第一个输入为家谱中的某成员,该行接着输入的信息为该成员两个孩子的姓名(保证除第一行的第一个成员外,每行第一个成员都在之前输入过)。输入完毕后,最后一行输入两个成员(保证已输入过),为要求查找的两个家谱成员的关系,输出内容包括他们最近邻的共同祖先的名字以及在家谱中相差的层次数。测试用例1:输入:Ye Shu BaShu Ge Mei1Ba Self Mei2Ge Son1 Son2Son2 Mei1输出:Shu 1

2021-02-20 15:40:29 120

原创 2021-02-20

北航机试 2019 机场送旅客先输入n(n < 10000),代表有n组数据,接下来n行每行输入四个数,第一个输入为分支节点,后三个输入为其三个孩子节点(-1代表子节点不存在)。输入的n行中第一行第一个节点为根节点,作为起点。保证输入的结点至多有一个父节点。然后输入m(m < n),接下来输入m个客户,每行输入他的目标(叶节点)和优先级(数字越小越优先,保证不会有相同优先级),要求从起点出发,按照优先级把客户送到目标节点,然后从该节点继续运送下一个客户至其目标(叶节点),全部运送完毕后返回

2021-02-20 11:17:32 125

原创 2021-02-20

北航机试 2019 网络打印机一个网络中有三种设备:交换机、电脑和打印机,网络成树状,电脑和打印机只在叶子节点上。交换机有4个端口。首先输入一个数N表示设备的个数。然后按照id,类型,父节点id,端口号依次输入每台设备最后输入一个id(电脑),找距离这台电脑最近的打印机,如果有多个则按照前序遍历的顺序找到打印机输出这台打印机的编号和从电脑到这台打印机的路径。输入:当前网络中设备数m<设备ID><设备类型><设备父节点ID><端口号>(类型:0

2021-02-20 11:05:24 144

原创 2021-02-20

北航机试 2018 线段合并这题网上的说法不太一致,我看到了两个版本的题目,主要的区别在于两个线段允许的连接方式,从慕弋云子的那本北航机试指南 的来看,连接方式限定为“头尾相接”,即规定x坐标小的一点为线段的左端点,另一个则为右端点,规定两个线段连接的方式为“左端点连接右端点”,即线段A的左端点和线段B的右端点相同,则AB相连。而另外一种连接方式则没有什么限制,只规定端点相同的线段就可以连接。至于真实的情况是怎么样的,我也不清楚。这里就按照第一种限制条件来解题。题目一:在二维空间中给定一定数量的线

2021-02-20 10:46:22 109

原创 2021-02-18

codeup 问题 C: 最短路径边权是二的整数幂,很大的数,int保存不可能,类似大整数保存下来,模拟加法操作和小于操作,因为是二进制数,操作比一般的大整数要简单,只是用的是稀疏表示,要注意有序。其实不用稀疏表示,也是可以的,因为总共就500个比特位,不多不少,开一个bool[500]的数组,表示一位是否存在,这样加法操作就是O(1)了。开始的时候想错了,以为直接用指数代替幂进行Dijkstra就行了,最后记录路径再把真正的距离算出来。但是太天真了,错误的具体论证可以看注释,简单来说就是一些在以2的幂

2021-02-18 11:40:55 71

原创 2021-02-18

codeup 问题 C Legal or Not#include <cstdio>#include <queue>#include <algorithm>using namespace std;/*有向图判环。两种方法:1. 拓扑排序判环。2. DFS判环。本质上也是拓扑排序。 */int N, M;#define MAXN 105bool G[MAXN][MAXN];int In[MAXN];bool TopoSort() { qu

2021-02-18 10:46:06 52

原创 2021-02-18

codeup 问题 D 【宽搜入门】魔板超时/超内存了很久,最后用散列解决了超时,用占空间最小的散列bool数组解决了超内存。应该有比单纯BFS更高效的算法吧。我这个就是BFS暴力搜索。#include <cstdio>#include <queue>#include <cstring>#include <cassert>#include <string> // op是逆序产生的。 using namespace std;cons

2021-02-18 09:35:45 72

原创 2021-02-12

PAT (Advanced Level) Practice1021 Deepest Root (25 分)一开始只想到暴力法,即枚举所有节点作为树根,计算树高,得出最大树高。显然有很多重复枚举,最简单的,比如u为根的树,最深的节点为v,则显然以v为根的树,最深的节点肯定也是u,所以算了以u为根,就不用算以v为根。《算法笔记》的参考程序给出了一个定理,直接给出了高效的求法,实现倒不难,就要理解这个定理为什么是对的,要费点脑子。这个定理的关键是要注意到,所有的最长路径(即树的直径),都有一段公共路径,因此

2021-02-12 20:28:23 74

原创 2021-02-09

codeup 问题 D More is better#include <cstdio>#include <cstring>#include <cassert>/* run this program using the console pauser or add your own getch, system("pause") or input loop *//*并查集求最大联通分量的节点数。 房子里的人必须互相为朋友,说明是一个联通图,题目要求人数尽量多

2021-02-09 16:33:21 73

原创 2021-02-09

codeup 问题 B 序列合并#include <cstdio>#include <cmath>#include <algorithm>#include <cassert>using namespace std;#define MAXN (100000+5)int N;struct Heap { int heap[MAXN]; int N; /* 大顶堆。 */ void DownAdjust(int low, int hi)

2021-02-09 16:23:06 80

原创 2021-02-08

CCF-CSP\专题\题型A 简单模拟\201803-2 碰撞的小球#include <cstdio>#include <cstring>#include <algorithm>using namespace std;/* run this program using the console pauser or add your own getch, system("pause") or input loop */int N,L,T;// N个小球,

2021-02-08 10:36:51 68

原创 2021-02-08

CCF 202012-2 期末预测之最佳阈值#include <cstdio>#include <algorithm>using namespace std;/* run this program using the console pauser or add your own getch, system("pause") or input loop *//*对每个(x,r),求出大于等于x且r==1的个数,以及小于x且r==0的个数,这两个数值相加,就是以x为

2021-02-08 10:34:31 191

原创 2021-02-07

CCF 带配额的文件系统 100分#include <cstdio>#include <map>#include <vector>#include <iostream>#include <string>#include <cstring>#include <cctype>#include <cassert>using namespace std;typedef long long ll;

2021-02-07 23:47:27 87

原创 CCF 202009-3点亮数字人生 (100分)

CCF 202009-3点亮数字人生 (100分)#include <cstdio>#include <vector>#include <cstring>#include <algorithm>#include <cstdlib>#include <cassert>using namespace std;enum { NOT, AND, OR, XOR, NAND, NOR,};#define MAX

2021-02-07 23:44:56 985 1

高清扫描head first design pattern

比现在csdn上的headfirst design pattern要清晰得多

2016-09-02

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除