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 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> [PAT]PAT甲级2021秋季——经验和总结、“尽人事,听天命!” -> 正文阅读

[数据结构与算法][PAT]PAT甲级2021秋季——经验和总结、“尽人事,听天命!”

说在前面

  • 其实博主最初想要考PAT的初衷就是为了抵浙大的机试,但是今年很不幸的是,PAT不能抵浙大的机试啦!(而且还是在不能退钱的后一天发的政策hhh)但是这仍然是一次模拟浙大机试的过程吧,而且能系统的学习一些机试相关的内容,虽然还上升不到能够去打比赛的程度,但是自己也在过程中收获了许多快乐,感觉写算法题学数据结构还是很快乐的!这或许是我仍在坚持cs的理由吧!
  • 不知道是不是这次考试比较简单的缘故,我居然考了71分!我在考试前一天写往年模拟题的时候得了2分,然后还没有复习到树和图相关的内容,所以最终考了这个分数我真的是很惊喜的!虽然网上有很多大佬刷20题就能考满分,很遗憾我不是这样的大佬,但是就是想和大家说一下:一定要坚持,不要放弃,结果会让你很惊喜的!
  • 以及这个考试能够抵一些企业的笔试~其实真情实感,我觉得笔试是企业面试最水的一个环节,总的来说我觉得算法小白拿这个PAT来系统的学一下机试,还是可以的,别的就没有什么体会啦。

准备过程

我准备的程度大概就是王道刚写到第八章(大家看我的博客就知道。。),所以第九章搜索、第十章数据结构(树、优先队列、散列)、第十一章图论,我是没看的。解题的时候都是用数组来模拟树和图的数据结构,方法也很暴力。还有王道第十二章是动态规划,这一部分求职面试经常问。
写了一套真题(认真写、并总结分析了)
然后就直接考试了。
我觉甲级里面的题还是很套路的吧,你写题写多了,思路自然就会有了,当然有的人写的算法更有效率一些,这才是区别吧,我觉得大家认真复习认真写都是没什么问题的!!

如果你的目标是高分,直接刷历年真题并总结,基础不行就先看晴神宝典(PAT考试经验总结里博主总结的,有的章节不考,codeup上的题也不用刷),就这么简单!!!!

考研保研er准备机试也差不多是这个道理!!~(清北机试除外,没写过,别的学校的差不多,都没多难的题,毕竟不是acm,但是有的学校很奇葩考的特别,不是这种常规机试题,就不说了)

A题

  • 简单模拟题,题目说啥你做啥就行

我看有很多人卡在A题,没拿满分,但是我拿满分了!!
我刚开始也只拿了11分,后来思考了一下,我是卡在了输出一共declare了多少个数组。刚开始我的计数方式是检索了哪个数组就+1,但是不是这样的!因为它的是 A 0 A_0 A0?溢出了declare A 1 A_1 A1?,以此类推,所以要记录最大declare的数组数。

我写循环的方式很奇葩,大家可以忽略

#define _CRT_SECURE_NO_DEPRECATE
#include <cstdio>

using namespace std;

int n, k;

struct block {
	long long start_add;
    int len;
	int used = false;
};

block blocks[10001];

long long GetAdd(int index) {
	int i_th = 0;
	index -= blocks[i_th].len;
	while (index >= 0) {
		i_th++;
		index -= blocks[i_th].len;
	}
	
	index += blocks[i_th].len;
	blocks[i_th].used = true;

	return blocks[i_th].start_add + index * (sizeof(int));
}

int main() {
	
	scanf("%d %d", &n, &k);

	for (int i = 0; i < n; ++i) {
		scanf("%lld %d", &blocks[i].start_add, &blocks[i].len);
	}

	int total_len = 0;
	for (int i = 0; i < n; ++i) {
		total_len += blocks[i].len;
	}

	for (int i = 0; i < k; ++i) {
		int index = 0;
		scanf("%d", &index);
		if (index > total_len - 1) {
			printf("Illegal Access\n");
		}
		else {
			printf("%lld\n", GetAdd(index));
		}
	}

	int index = 0;
	for (int i = n - 1; i >= 0; --i) {
		if (blocks[i].used) {
			index = i;
			break;
		}
	}

	printf("%d", index + 1);
	return 0;
}

B题

  • 简单模拟题,题目说啥你做啥就行

从输入帽子列表的最后一个帽子开始分配帽子,找到对应体重的owner就可以了,还是很简单的,一下子就过了。

#define _CRT_SECURE_NO_DEPRECATE
#include <cstdio>
#include <algorithm>

using namespace std;
int n;
int hats[10001];


struct owner {
	int weight;
	int index;
};

owner owners[10001];

bool Compare(owner a, owner b) {
	return a.weight < b.weight;
}

int Getorder(int i) {
	int count = 0;
	for (int j = 0; j < n; ++j) {
		if (hats[j] < hats[i]) {
			count++;
		}
	}
	return count;
}

int main() {

	scanf("%d", &n);
	for (int i = 0; i < n; ++i) {
		scanf("%d", &hats[i]);
	}

	for (int i = 0; i < n; ++i) {
		scanf("%d", &owners[i].weight);
		owners[i].index = i + 1;
	}

	sort(owners, owners + n, Compare);

	for (int i = n - 1; i >= 0; --i) {
		printf("%d", owners[Getorder(i)].index);
		if (i != 0) {
			printf(" ");
		}
	}

	return 0;
}

C题

遍历图,不重复遍历,每次选择index小的结点,不知道有没有什么算法可以实现,但我属于不知道算法,只能暴力遍历hhh

写完代码测试发现WA,debug发现卡在了起始点为8时的遍历,我原本写的i == n && playground[current][i] == 0跳出条件当start=9,current=5的时候会卡在死循环里永远跳不出去哈哈哈啊哈然后稍微改了一下,但是我觉得又合理又不合理的ovo

我变量取名是不是很可爱哈哈哈哈!

#define _CRT_SECURE_NO_DEPRECATE
#include <cstdio>

using namespace std;

int n, m;
int playground[110][110];
bool visit[110] = { 0 };

int SearchPlayground(int start) {
	bool visit[110] = { 0 };
	visit[start] = true;
	int current = start;
	int count = 1;
	while (count != n) {
		for (int i = 1; i <= n; ++i) {
			if ((playground[current][i] == 1)&&(!visit[i])) {
				current = i;
				count++;
				visit[i] = true;
				break;
			}
			if (i == n && playground[current][i + 1] == 0) { // 这个判断条件有待商榷 and 优化
				return count;
			}
		}
	}
	return count;
}

int FindStart() {
	int start = 1;
	for (int i = 1; i <= n; ++i) {
		if (SearchPlayground(i) > SearchPlayground(start)) {
			start = i;
		}
	}
	return start;
}


int main() {

	scanf("%d %d", &n, &m);
	
	for (int i = 0; i < m; ++i) {
		int start, end;
		scanf("%d %d", &start, &end);
		playground[start][end] = 1;
		playground[end][start] = 1;
	}



	int begin = FindStart();


	printf("%d %d", begin, SearchPlayground(begin));
	return 0;
}

D题

  • 树的建立、小顶堆

在头一天总结了一套试卷,有大顶堆,然后这道题大概的思路就有了。
but,前序建树我不会啊55555肠子都悔青了,要是头一天晚上没有被那套考了2分的模拟卷(写了一会写不出来直接交卷了)打击了自信心,已经抱着做慈善的心态去面对转天的考试了!

没建树,而且按照大顶堆的方式建立的小顶堆。后期看到题目我会重写一遍所以不要参考!

#define _CRT_SECURE_NO_DEPRECATE

#include <cstdio>
#include <algorithm>

using namespace std;

struct node {
	int key;
	int priority;
};

node nodes[31];

void up(int index) {
	for (int i = index; nodes[i / 2].priority > nodes[i].priority && i > 1; i /= 2){
		swap(nodes[i], nodes[i / 2]);
	}
}

int main() {
	int n;
	scanf("%d", &n);
	for (int i = 1; i <= n; ++i) {
		scanf("%d %d", &nodes[i].key, &nodes[i].priority);
	}

	for (int i = n; i >= 1; i--) {
		up(i);
	}

	for (int i = 1; i <= n; ++i) {
		printf("%d", nodes[i].key);
		if (i != n) {
			printf(" ");
		}
	}


	printf("\n");


	for (int i = 1; i <= n; ++i) {
		printf("%d", nodes[i].priority);
		if (i != n) {
			printf(" ");
		}
	}

	return 0;
}

最后的一点点感想

so,不要着急,要有耐心,不要急于求成,模拟不考100分就不行,我觉得人生大多数事情,都是努力了就会有好结果的,这是我坚信不疑的。
虽然现在大家都想躺平,觉得努力了也不如天龙人身份(北京户口),甚至努力工作都是在被资本家压榨,打工就是被压榨,所以躺平就是最好的选择。(行业需要整改,但绝对不是以所有人都躺平的方式来抗击的,这价值观就很危险)hhh,所以一定要记住一件事
“收获只会出现在你努力的方向上”
努力学习复习功课考试,你会收获好的分数高绩点,保研资格,但你不一定能收获好的工作,保去最好的学校。
努力准备算法题、面经、积累项目经历,你会收获好的工作offer,但不一定就是谷歌微软BAT。
拿到offer努力工作,你会收获高薪,但不一定能赚够北京一套房,还钱多事少离家近。

你这么努力奋斗,你在过程中认识自我、实现自我,找到热爱的事情、最想过的生活、最想成为的自己,活得独立、体面、有尊严,这还不够有意义吗?如果非要和那些不努力但是出生就决定他/她的起点注定是你的终点的人比,然后觉得努力没用,就丧了,躺平了。
难道就没有考虑过,这完全就是两条赛道吗,完全不相关呀。收获只会出现在努力的方向上!所以xdm冲呀!

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-09-14 13:36:45  更:2021-09-14 13:39:15 
 
开发: 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/1 22:39:02-

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