PAT考试总结(考试心得)

pat试题总结遍历问题的总结dfs中,如果是有环的图,要设置visited数组防止绕圈,同时在dfs函数退出前要将visited数组相应设置为false,否则其他路径就不能遍历该结点;在问题中,如果要求“从一个序列中选取若干个元素来满足条件”,可以考虑dfs,如1103IntegerFactorization(30分)和7-1Forever(20分);字符串处理总结字符串处理中,注意利用sscanf,可以按照格式读取字符串中的数字,如sscanf(s,“Therootis

大家好,又见面了,我是你们的朋友全栈君。

pat试题总结

遍历问题的总结

  1. dfs中,如果是有环的图,要设置visited数组防止绕圈,同时在dfs函数退出前要将visited数组相应设置为false,否则其他路径就不能遍历该结点;
  2. 在问题中,如果要求“从一个序列中选取若干个元素来满足条件”,可以考虑dfs,如1103 Integer Factorization (30分)7-1 Forever (20分)
  3. 在写dfs前,罗列需要设置的全部变量,然后在dfs边界上,逐一考虑对这些变量的值的修改,可以避免漏掉某个变量的修改;
  4. 动手写代码前仔细考虑“什么由什么确定”可以省去debug时的思维定势,如1131 Subway Map (30分)通过两个邻站作为键可以确定一条线路,但是考察“两个邻站都属于哪条线路”却不能确定线路;又如1018 Public Bike Management (30分),发车数send和收回数back并不满足最优子结构,靠贪心算法选择路径是行不通的。

字符串处理总结

  1. 字符串处理中,注意利用sscanf,可以按照格式读取字符串中的数字,如
    sscanf(s, “The root is %d”, &root)提取int型变量root;
  2. 当不合法情况较多时,不逐个判断不合法的情况,而是只允许合法的情况通过,如判断是否合法数字:只可能有一个小数点、若干位数字、负号只能有一个且出现在头部。
  3. 熟悉数字和字符串的互相转化。

数学问题总结

  1. 数学问题中,常用的函数如下:
//辗转相除法求最大公因数
int gcd(int a, int b) { 
   
	return b == 0 ? a: gcd(b, a % b);
}
//埃筛对素数进行打表
bool prime[100];
void getPime() { 
   
	fill(prime + 2, prime + 100, true);
	for(int i = 2; i < 100; i++) { 
   
		if(prime[i]) { 
   
			int factor = 2;
			while(i * factor < 100) { 
   
				prime[i * factor] = false;
			}
			++factor;
		}
	}
}
//判断素数的函数
bool isPrime(int num) { 
   
	int n = sqrt(num);
	for(int i = 0; i <= n; i++) { 
   
		if(num % i == 0)
			return false;
	}
	return true;
}
  1. 在一些处理中,可以考虑负号、小数点单独处理,可以有效化简判断条件;
  2. 进制转换,主要用除基取余法和乘基取整法。
  3. 没有好方法时,尝试找规律化简解法。

排序问题的总结

  1. 熟记各种排序代码的编写。
    插入排序:每次将无序的子数组中的头部元素插入到有序子数组中;
    冒泡排序:游标从前往后扫描,如果前后两个元素逆序,则交换;
    选择排序:每次从无序部分选一个最小的,和有序部分的后面的元素交换;
    快速排序:选取数组中的一个元素作为pivot,将它藏到最左边,两个游标left, right根据pivot的大小不断交换元素,当两游标相遇时,left指示的就是pivot应该放的位置;
    堆排序:先自底向上建堆,每次从堆顶拿出元素,用数组尾的元素顶上,然后将堆顶元素下滤;
  2. 对时间的处理,可以先将时间化成秒为单位,必要时再转换回时分秒。
  3. 必要时先剔除无效数据,从有效数据中寻找结果;
  4. 当一个问题有多个查询时,先处理好数据,在处理查询时可以直接返回结果。如果每查询一次就排序一次,可能会超时;
  5. 仔细阅读排序条件,避免遗漏或出错。

树类问题的总结

  1. 熟记给出两个序列构造树的代码以及1119 Pre- and Post-order Traversals (30分)前序和后序不唯一地建树;
  2. 熟记AVL树左旋、右旋的写法,注意旋转后要更新子结点和和父结点的高度,注意更新高度的时机;
  3. 先写好模版代码,再根据问题需要修改;
  4. 思考实现的代码和问题的描述逻辑上的不一致,如1135 Is It A Red-Black Tree (30分)要求的是”每个结点到叶结点的黑结点数相同“,而不仅仅是根结点到叶结点。

模拟问题的总结

  1. 合适地选取数据结构,如1129 Recommendation System 数据出现的次数不断变化,同时又要求根据出现次数有序,所以考虑红黑树实现的set
  2. 充分考虑、化简模拟的事件要满足的条件,如1128 N Queens Puzzle (20分)中,”两个皇后不能在同一对角线“,说明两个皇后连线的斜率不能为1;
  3. 当模拟的事件有时间轴时,考虑设置一个变量模拟时间的流逝。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/128736.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 详解scheduleAtFixedRate与scheduleWithFixedDelay原理

    详解scheduleAtFixedRate与scheduleWithFixedDelay原理前言前几天,肥佬分享了一篇关于定时器的文章你真的会使用定时器吗?,从使用角度为我们详细地说明了定时器的用法,包括fixedDelay、fixedRate,为什么会有这样的区别呢?下面我们从源码角度分析下二者的区别与底层原理。jdk定时器这里不再哆嗦延迟队列、线程池的知识了,请移步下面的链接延迟队列原理,http://cmsblogs.com/?p=2448线程池原理,http://…

    2025年8月6日
    2
  • java培训学校杭州_杭州Java培训班

    java培训学校杭州_杭州Java培训班前言这段时间也一直在学习Netty相关知识,因为涉及知识点比较多,也走了不少弯路。目前网上关于Netty学习资料玲琅满目,不知如何下手,其实大家都是一样的,学习方法和技巧都是总结出来的,我们在没有找到很好的方法之前不如按部就班先从基础开始,一般从总分总的渐进方式,既观森林,又见草木。Netty是一款提供异步的、事件驱动的网络应用程序框架和工具,是基于NIO客户端、服务器端的编程框架。所以这里我们先以NIO和依赖相关的基础铺垫来进行剖析讲解,从而作为Netty学习之旅的一个开端。为什么学Java?Jav

    2022年10月3日
    2
  • 2016年四川省TI杯电子设计竞赛B题

    2016年四川省TI杯电子设计竞赛B题B题:自动循迹小车1.任务设计制作一个自动循迹小车。小车采用一片TI公司LDC1314或LDC1000电感数字转换器作为循迹传感器,在规定的平面跑道自动按顺时针方向循迹前进。跑道的标识为一根直径0.6~0.9mm的细铁丝,按照图1的示意尺寸,用透明胶带将其贴在跑道上。图中所有圆弧的半径均为为20cm±2cm。图1跑道示意图2.要求(1)在图1小车所在的直线区任意指定一

    2022年6月7日
    31
  • PS2手柄-1「建议收藏」

    PS2手柄-1「建议收藏」相关定义Comd[2]={0x01,0x42};存储了两条指令码,分别是开始指令和请求数据指令。Data[9]={0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00};数据存储数组,初始全为0。MASK[16]={PSB_SELECT,PSB_L3,PSB_R3,PSB_START,PSB_PAD_UP,PSB_PAD_RIGHT,PSB_PAD_DOWN,PSB_PAD_LEFT,PSB_L2,PSB_R2,PSB_L1,PSB_R1,PSB_GREEN,P

    2022年6月11日
    36
  • mt4历史数据下载位置_头榜土豪数据中心

    mt4历史数据下载位置_头榜土豪数据中心    打开MT4,按F2,会出现一个历史数据中心对话框。之前,我直接按下载按钮时,往往下载数据会出错。因此百度了很久,也查看了很多的处理方式,觉得都不尽如人意。不是数据找不到,就是即使找到了下载时也出现问题。    近日又捣弄了一番,跑到MT4中的history文件夹,发现里面有各个我以前申请的模拟帐户,而且是不同公司下的帐户。这突然让我意识到,我在历史数据中心对话框中点击下载时出现的警

    2022年8月15日
    6
  • SpringCloud确保服务只能通过gateway转发访问,禁止直接调用接口访问

    点击上方“全栈程序员社区”,星标公众号 重磅干货,第一时间送达 作者:Hpsyche blog.csdn.net/Hpsyche/article/details/102926010…

    2021年6月28日
    247

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号