这四道题来自 13 年 08 月 30 的 PAT 测试。

代码量不大,思路也比较直接。不过第一题的处理逻辑不太清晰,需要好好把握。稍有不慎就掉进坑里了(很多人被这道 20‘的题坑了一个多小时心慌意乱我会乱说-,-?)。

PAT advanced level 全部源码:请戳

1061. Dating (20)

题意

题意比较模糊,需要仔细对照 Sample 的数据理清思路。给定四个字符串,每个不超过 60 个字符,不含空格。要求从中找到符合如下规定的三个字符(或者它们的位置),并转化成一个时间的表达:

  • 1.依次比较前两个字符串中每个位置的元素,找到第一个相等的字符,且该字符属于[‘A’, ‘G’]的字母,注意大小写敏感。转换成一周七天输出。
  • 2.在 1 中的字符出现之后,继续比较前两个串,找到一个相等的字符,使它属于[‘0’, ‘9’] || [‘A’, ‘N’],同样,大小写敏感。转换成一天 24 小时的小时数输出。
  • 3.比较后两个字符串,找到第一个相等的字母(isalpha()),将它在数组中的位置值转换分钟数输出。

为了便于理解,给出 Sample 数据:

1
2
3
4
5
6
7
8
9
10
Sample Input:

3485djDkxh4hhGE
2984akDfkkkkggEdsb
s&hgsfdk
d&Hyscvnm Sample Output: THU 14:04
分析

理清题目的逻辑以后,实现起来是很简单的。

pat1061 源码:请戳

1062. Talent and Virtue (25)

题意

给定一堆人,每个人有三条记录:id,道德值(v),才能值(t)。给出两个值 L 和 H,用作对这堆人的分类。按照如下规则输出排序结果:

  • 0.过滤掉 v 和 t 都小于 L 的人
  • 1.v 和 t 都不小于 H 的人是圣人,属于最高的层级,排序在其他层级之前。
  • 2.v 不小于 H,而 t 小于 H 的人是君子,这个层级排在圣人之后。
  • 3.剩下的人中,v 不小于 t 的人是愚人,层级关系里排第三,排在所有圣人和君子之后。
  • 4.最后剩下的人是小人,是最低的层级。
  • 5.排名时,相同层级的人的排序关系是 1.按照 v+t 的总分 non-increasing 排序;2.按照 v 的分值按 non-increasing 排序;3.找到 id 按 increasing 排序。
分析

题意梳理清楚以后,定制比较函数用 qsort()能很快的实现。

经测试,使用coutcin会超时,改用’printf() scanf()’轻松过。

pat1062 源码:请戳

1063. Set Similarity (25)

题意

题目给出了 N(<=50)个正整数集合(实际上不是真正意义上的 set,有重复数值),每个集合最多存 M(<104)个元素,其中数值范围是 [0, 109]。给出 K 次查询,每次查询条件为两个集合,要求求出两集合的相似度。

这里集合相似度的定义是 Nc/Nt*100%,其中 Nc 为两集合的交集元素数量,Nt 为两集合的并集的元素数量。

分析

使用set给集合去重会超时。利用sort()对数组做排序,然后自行遍历去重是一个不错的方式。计算交集、并集的时候,直接用两个游标对数组遍历进行比较操作,复杂度为 O(M*K)。这种游标遍历的思想,还是很 common sense 的处理流程。

pat1063 源码:请戳

1064. Complete Binary Search Tree (30)

题意

给定一串数据,要求构建完全二叉搜索树。

分析

常规思路是对数据排序,然后递归的构建二叉搜索树(且构建的递归过程要满足完全二叉的树形结构),实现起来稍微有些代码量。

后来@Redow7 给介绍了一种更有趣的方法:

  • 0.对数据排序,等待操作。
  • 1.首先构建好完成二叉树。
  • 2.利用二叉搜索树的中序遍历的有序性,在中序遍历的过程中,将排序好的数据插入其中。

那么难点就降低到了构建完全二叉树。这又让人联想到了最大堆的数组实现:左儿子2*n,右儿子’2*n+1’。对的,数组实现的二叉树就是满足完全二叉树的特点的。于是,使用数组实现的二叉树做迭代的思路就出来了。

pat1064 源码:请戳

 原文地址:http://biaobiaoqi.github.com/blog/2013/08/31/pat-1061-pat-1064/
 版权声明:自由转载-非商用-非衍生-保持署名| Creative Commons BY-NC-ND 3.0

PAT 1061 - 1064 题解的更多相关文章

  1. PAT甲题题解-1061. Dating (20)-字符串处理,水水

    #include <iostream> #include <cstdio> #include <algorithm> #include <string.h&g ...

  2. PAT甲题题解-1064. Complete Binary Search Tree (30)-中序和层次遍历,水

    由于是满二叉树,用数组既可以表示父节点是i,则左孩子是2*i,右孩子是2*i+1另外根据二分搜索树的性质,中序遍历恰好是从小到大排序因此先中序遍历填充节点对应的值,然后再层次遍历输出即可. 又是一道遍 ...

  3. PAT Basic 1064

    1064 朋友数 如果两个整数各位数字的和是一样的,则被称为是“朋友数”,而那个公共的和就是它们的“朋友证号”.例如 123 和 51 就是朋友数,因为 1+2+3 = 5+1 = 6,而 6 就是它 ...

  4. 2019秋季PAT甲级_C++题解

    2019 秋季 PAT (Advanced Level) C++题解 考试拿到了满分但受考场状态和知识水平所限可能方法不够简洁,此处保留记录,仍需多加学习.备考总结(笔记目录)在这里 7-1 Fore ...

  5. PAT 甲级 1064 Complete Binary Search Tree (30 分)(不会做,重点复习,模拟中序遍历)

    1064 Complete Binary Search Tree (30 分)   A Binary Search Tree (BST) is recursively defined as a bin ...

  6. PAT 乙级 1064 朋友数(20) C++版

    1064. 朋友数(20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 如果两个整数各位数字的和是一样的,则被 ...

  7. PAT 1061 判断题(15)(代码)

    1061 判断题(15 分) 判断题的评判很简单,本题就要求你写个简单的程序帮助老师判题并统计学生们判断题的得分. 输入格式: 输入在第一行给出两个不超过 100 的正整数 N 和 M,分别是学生人数 ...

  8. PAT甲题题解-1068. Find More Coins (30)-dp,01背包

    一开始没多想,虽然注意到数据N<=10^4的范围,想PAT的应该不会超时吧,就理所当然地用dfs做了,结果最后一组真的超时了.剪枝啥的还是过不了,就意识到肯定不是用dfs做了.直到看到别人说用0 ...

  9. PAT甲题题解-1108. Finding Average (20)-字符串处理

    求给出数的平均数,当然有些是不符合格式的,要输出该数不是合法的. 这里我写了函数来判断是否符合题目要求的数字,有点麻烦. #include <iostream> #include < ...

随机推荐

  1. VMware Ubuntu安装具体过程

    不是每个程序猿都必须玩过linux,仅仅是博主认为如今的非常多server都是linux系统的,而自己属于那种前端也搞.后台也搞,对框架搭建也感兴趣,可是非常多生产上的框架和工具都是安装在server ...

  2. linux内核头文件 cdev.h 解析

    遇到一个内核API--cdev_init 就找到这里来了. #ifndef _LINUX_CDEV_H #define _LINUX_CDEV_H #include <linux/kobject ...

  3. 8.4 Android灯光系统_源码分析_电池灯

    电池灯的Java代码在batteryservice.java中 电池的状态电量等信息由驱动获得,但驱动不会主动做这些事情,因此肯定有个App调用驱动程序读取电池信息,称这个App为A应用. 还有个Ap ...

  4. [Nuxt] Update Vuex State with Mutations and MapMutations in Vue.js

    You commit changes to state in Vuex using defined mutations. You can easily access these state mutat ...

  5. sql海量数据优化

    1.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而进行全表扫描,如: select id from t where num is null 可以在num上设 ...

  6. 24、vb2_buffer和videobuf_buffer比较分析

    看韦东山视频第三期摄像头驱动中构造了自己的vivi驱动,但是使用的videoBuf结构体,新的版本用的是vb2_buffer结构,我机器上(ubuntu12.04)使用的内核是linux3.2,看了看 ...

  7. 问题:CListCtrl如何高亮选中一行 http://zhidao.baidu.com/question/100664911.html 扩展:单行、双行及完成状态的字体等等。。。

    http://zhidao.baidu.com/link?url=BKp05mfOdKbEBh21svQelpVhYjzDkIpYUZay8_3ZLSndTQn5kK0eTwQG8jBvYnwh8US ...

  8. [Jade] Use Mixins in Pug

    Mixin works as a function. extends layout include mixins/storeForm block content .inner h2 #{title} ...

  9. stm32的DMA重新工作

    下面是在战舰V3寄存器程序例子中找到的: //开启一次DMA传输void MYDMA_Enable(DMA_Channel_TypeDef*DMA_CHx){    DMA_CHx->CCR&a ...

  10. HTTP请求头与响应头

    http://m.blog.csdn.net/article/details?id=48918857 本篇文章中,将学习一下HTTP请求头与响应头的知识. 一.HTTP头引入: 正确的设置HTTP头部 ...