PAT (Advanced Level) 1132~1135:1132 模拟 1133模拟(易超时!) 1134图 1135红黑树
1132 Cut Integer(20 分)
题意:将一个含K(K为偶数)个数字的整数Z割分为A和B两部分,若Z能被A*B整除,则输出Yes,否则输出No。
分析:当A*B为0的时候,不能被Z整除,输出No。否则会出现浮点错误。
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<string>
#include<algorithm>
#include<map>
#include<iostream>
#include<vector>
#include<set>
#include<cmath>
using namespace std;
char s[20];
int main(){
int N;
scanf("%d", &N);
while(N--){
scanf("%s", s);
int len = strlen(s);
int A = 0;
for(int i = 0; i < len / 2; ++i){
A = A * 10 + s[i] - '0';
}
int B = 0;
for(int i = len / 2; i < len; ++i){
B = B * 10 + s[i] - '0';
}
int C = A * B;
if(C == 0){
printf("No\n");
continue;
}
int x = atoi(s);
if(x % C == 0) printf("Yes\n");
else printf("No\n");
}
return 0;
}
1133 Splitting A Linked List(25 分)
题意:给定一个链表,将链表重新排序,在不打乱原链表相对顺序的前提下,小于0的在最前面,其次是0~K,最后是大于K的数。
分析:
1、3次遍历可实现链表重排。
2、map映射value和pre或suc的关系会超时,所以,以pre为结点定义结构体,组织链表的重排,从而进行优化。
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<string>
#include<algorithm>
#include<map>
#include<iostream>
#include<vector>
#include<set>
#include<cmath>
using namespace std;
const int MAXN = 100000 + 10;
struct Node{
int pre, value, suc;
}num[MAXN];
vector<int> old, ans;
int main(){
int N, K, head, pre, value, suc;
scanf("%d%d%d", &head, &N, &K);
for(int i = 0; i < N; ++i){
scanf("%d%d%d", &pre, &value, &suc);
num[pre].pre = pre;
num[pre].value = value;
num[pre].suc = suc;
}
while(head != -1){
old.push_back(head);
head = num[head].suc;
}
int len = old.size();
for(int i = 0; i < len; ++i){
if(num[old[i]].value < 0) ans.push_back(old[i]);
}
for(int i = 0; i < len; ++i){
if(num[old[i]].value >= 0 && num[old[i]].value <= K) ans.push_back(old[i]);
}
for(int i = 0; i < len; ++i){
if(num[old[i]].value > K) ans.push_back(old[i]);
}
for(int i = 0; i < len - 1; ++i){
printf("%05d %d %05d\n", ans[i], num[ans[i]].value, ans[i + 1]);
}
printf("%05d %d -1\n", ans[len - 1], num[ans[len - 1]].value);
return 0;
}
1134 Vertex Cover(25 分)
题意:vertex cover是指图中一些点的集合,使得图中每一条边的两个点中都至少有一个点在该点集中。给定点的集合,判断是否为vertex cover。
分析:按题意模拟即可。
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<string>
#include<algorithm>
#include<map>
#include<iostream>
#include<vector>
#include<set>
#include<cmath>
using namespace std;
const int MAXN = 10000 + 10;
int N, M;
bool vis[MAXN];
struct Edge{
int u, v;
void read(){
scanf("%d%d", &u, &v);
}
}num[MAXN];
int main(){
scanf("%d%d", &N, &M);
for(int i = 0; i < M; ++i){
num[i].read();
}
int K;
scanf("%d", &K);
while(K--){
int n, x;
scanf("%d", &n);
memset(vis, false, sizeof vis);
while(n--){
scanf("%d", &x);
vis[x] = true;
}
bool ok = true;
for(int i = 0; i < M; ++i){
if(vis[num[i].u] || vis[num[i].v]) continue;
ok = false;
break;
}
if(ok) printf("Yes\n");
else printf("No\n");
}
return 0;
}
1135 Is It A Red-Black Tree(30 分
题意:给定一棵二叉搜索树的前序遍历序列,判断其是否为一棵红黑树。
分析:
1、红黑树是一棵平衡的二叉搜索树,满足以下条件:
(1)所有结点不是红色就是黑色;
(2)根结点是黑色;
(3)每一个为NULL的叶子结点是黑色;
(4)如果某结点是红色,其左右子结点都是黑色;
(5)对于每个结点,其到所有后代叶子结点经过的黑色结点数相同;
2、根据给定的前序遍历序列,结合二叉搜索树的定义可以建树。
3、递归检查条件4。
4、同理,递归统计左右子树的黑色结点数,来检查条件5。
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<string>
#include<algorithm>
#include<map>
#include<iostream>
#include<vector>
#include<set>
#include<cmath>
using namespace std;
const int MAXN = 30 + 10;
struct Node{
Node *left, *right;
int value;
};
struct Node *root;
bool ok;
void build(Node* &r, int x){
if(r == NULL){
r = (Node*)malloc(sizeof(Node));
r -> value = x;
r -> left = r -> right = NULL;
return;
}
if(abs(x) < abs(r -> value)){
build(r -> left, x);
}
else{
build(r -> right, x);
}
}
void judge_RedNode(Node* r){
if(!ok) return;
if(r -> left != NULL){
if(r -> value < 0 && r -> left -> value < 0){
ok = false;
return;
}
else judge_RedNode(r -> left);
}
if(r -> right != NULL){
if(r -> value < 0 && r -> right -> value < 0){
ok = false;
return;
}
else judge_RedNode(r -> right);
}
}
int judge_BlackNode(Node* r){
int leftcnt, rightcnt;
if(!ok) return -1;
if(r == NULL) return 1;
leftcnt = judge_BlackNode(r -> left);
rightcnt = judge_BlackNode(r -> right);
if(leftcnt != rightcnt){
ok = false;
return -1;
}
else{
if(r -> value > 0) ++leftcnt;
}
return leftcnt;
}
int main(){
int K;
scanf("%d", &K);
while(K--){
root = NULL;
int N, x;
scanf("%d", &N);
while(N--){
scanf("%d", &x);
build(root, x);
}
ok = true;
judge_RedNode(root);
judge_BlackNode(root);
if(root -> value < 0 || !ok){
printf("No\n");
}
else{
printf("Yes\n");
}
}
return 0;
}
PAT (Advanced Level) 1132~1135:1132 模拟 1133模拟(易超时!) 1134图 1135红黑树的更多相关文章
- PAT (Advanced Level) Practice(更新中)
Source: PAT (Advanced Level) Practice Reference: [1]胡凡,曾磊.算法笔记[M].机械工业出版社.2016.7 Outline: 基础数据结构: 线性 ...
- PAT (Advanced Level) Practice 1042 Shuffling Machine (20 分) 凌宸1642
PAT (Advanced Level) Practice 1042 Shuffling Machine (20 分) 凌宸1642 题目描述: Shuffling is a procedure us ...
- PAT (Advanced Level) Practice 1001-1005
PAT (Advanced Level) Practice 1001-1005 PAT 计算机程序设计能力考试 甲级 练习题 题库:PTA拼题A官网 背景 这是浙大背景的一个计算机考试 刷刷题练练手 ...
- PAT (Advanced Level) Practice 1046 Shortest Distance (20 分) 凌宸1642
PAT (Advanced Level) Practice 1046 Shortest Distance (20 分) 凌宸1642 题目描述: The task is really simple: ...
- PAT (Advanced Level) Practice 1041 Be Unique (20 分) 凌宸1642
PAT (Advanced Level) Practice 1041 Be Unique (20 分) 凌宸1642 题目描述: Being unique is so important to peo ...
- PAT (Advanced Level) Practice 1035 Password (20 分) 凌宸1642
PAT (Advanced Level) Practice 1035 Password (20 分) 凌宸1642 题目描述: To prepare for PAT, the judge someti ...
- PAT (Advanced Level) Practice 1031 Hello World for U (20 分) 凌宸1642
PAT (Advanced Level) Practice 1031 Hello World for U (20 分) 凌宸1642 题目描述: Given any string of N (≥5) ...
- PAT (Advanced Level) Practice 1027 Colors in Mars (20 分) 凌宸1642
PAT (Advanced Level) Practice 1027 Colors in Mars (20 分) 凌宸1642 题目描述: People in Mars represent the c ...
- PAT (Advanced Level) Practice 1023 Have Fun with Numbers (20 分) 凌宸1642
PAT (Advanced Level) Practice 1023 Have Fun with Numbers (20 分) 凌宸1642 题目描述: Notice that the number ...
- PAT (Advanced Level) Practice 1019 General Palindromic Number (20 分) 凌宸1642
PAT (Advanced Level) Practice 1019 General Palindromic Number (20 分) 凌宸1642 题目描述: A number that will ...
随机推荐
- springboot默认创建的bean是单实例
默认是单例 通过注解@Scope("prototype"),将其设置为多例模式 参考: 曾经面试的时候有面试官问我spring的controller是单例还是多例,结果我傻逼的回答 ...
- 【协作式原创】查漏补缺之乐观锁与悲观锁TODO
面试官:你了解乐观锁和悲观锁吗? 乐观锁和悲观锁是两种思想,用于解决并发场景下的数据竞争问题. 悲观锁的实现方式是加锁,加锁既可以是对代码块加锁(如Java的synchronized关键字),也可以是 ...
- where、having区别
where << group by << having where筛选是在分组之前筛选,筛选完之后再group by having是分组之后再筛选,筛选完之前先g ...
- Tomcat认识
Tomcat目录结构: bin:存放启动和关闭的一些脚本 common:共享(部署在该服务器上的一些)jar包 conf:存放服务器的一些配置文件 webapps:部署文件 work:服务器运行时,产 ...
- redis-key管理
redis-key管理 1. redis key 本章主要内容为redis key级别的操作命令. 参考文档:https://redis.io/commands 1.1. Redis ...
- 9 HTML DOM事件监听&版本兼容&元素(节点)增删改查
事件监听: 语法:element.addEventListener(event, function, useCapture); event:事件的类型,触发什么事件,注意不需要on作为前缀,比如cli ...
- spring配置文件1
applicationContext.xml: <?xml version="1.0" encoding="UTF-8"?><beans xm ...
- Vue - 监听页面刷新和关闭
一,在 created中 注册 页面刷新和关闭事件 created() { window.addEventListener('beforeunload', e => this.test(e)) ...
- Eclipse中java代码注释变成乱码的问题
今天在查看曾经写过的代码时发生了一件很是让人头疼的事: 我写的所有注释全部都变成了了乱码,曾经刚入门时也是经常遇到类似的问题,解决起来很快,每天可能都会在工作空间里看到,但是随着时间的推移,写代码的规 ...
- 32 commons-lang包学习
maven依赖 <dependency> <groupId>commons-lang</groupId> <artifactId>commons-lan ...