7-1  阅览室

题目:

天梯图书阅览室请你编写一个简单的图书借阅统计程序。当读者借书时,管理员输入书号并按下S键,程序开始计时;当读者还书时,管理员输入书号并按下E键,程序结束计时。书号为不超过1000的正整数。当管理员将0作为书号输入时,表示一天工作结束,你的程序应输出当天的读者借书次数和平均阅读时间。

注意:由于线路偶尔会有故障,可能出现不完整的纪录,即只有S没有E,或者只有E没有S的纪录,系统应能自动忽略这种无效纪录。另外,题目保证书号是书的唯一标识,同一本书在任何时间区间内只可能被一位读者借阅。

代码:

 1 #include<bits/stdc++.h>
2 using namespace std;
3 int main()
4 {
5 int a, b, book, ans = 0, k = 0, day;
6 char se[5];
7 map<int,int> m;
8 cin >> day;
9 while(day)
10 {
11 scanf("%d", &book);
12 scanf("%s%d:%d", &se, &a, &b);
13 if(book > 0)
14 {
15 if(se[0] == 'S')
16 m[book] = a * 60 + b;
17 else if(se[0] == 'E')
18 {
19 if(m.find(book) != m.end())
20 {
21 ans += a * 60 + b - m[book];
22 k++;
23 m.erase(book);
24 }
25 }
26 }
27 else
28 {
29 if(k != 0)
30 cout << k << " " << (int)(1.0 * ans / k + 0.5) << endl;
31 else
32 cout << "0 0" << endl;
33 k = 0;
34 ans = 0;
35 m.clear();
36 day--;
37 }
38 }
39 return 0;
40 }

思路:就是用map数组进行操作,而且进行时间操作的时候记得全部转换为分钟进行计算,也就是小时记得乘以60

注意:第一次用struct做的wa掉的点是同一本书被借多次,有不匹配,所以在用数组进行循环遍历的时候,排除多余的S或者E的时候是错的

7-9  树的遍历

题目:给定一棵二叉树的后序遍历和中序遍历,请你输出其层序遍历的序列。这里假设键值都是互不相等的正整数。

代码:

 1 #include<stdio.h>
2 #include<string.h>
3 #include<queue>
4 #include<stdlib.h>
5 #include<iostream>
6 using namespace std;
7 int btree[100]={0};//用于承装后续遍历的数字
8 int ctree[100]={0};//用于承装中序遍历的数据
9 struct node
10 {
11 node *l;
12 node *r;
13 int data;
14 };
15
16 int num=0;
17 int n;
18 node *creattree(int btree[],int ctree[],int n)//反向推算创建二叉树,注意这是指针
19 {
20 if(n<=0) return NULL;
21 node *T=new node();
22 int root=btree[n-1];//找到根节点
23 int k;
24 T->data=root;//创建树的节点
25 for(int i=0;i<n;i++)//由于中序遍历使两边分开
26 {
27 if(ctree[i]==root)
28 {
29 k=i;
30 break;
31 }
32 }
33 T->l=creattree(btree,ctree,k);//左子树
34 T->r=creattree(btree+k,ctree+k+1,n-(k+1));//右子树
35 return T;
36 }
37 void print(node *T)//层次遍历输出二叉树
38 {
39 node *p;//为中间变量
40 node *pr[100];
41 int rear=-1,front=-1;
42 rear++;
43 pr[rear]=T;//将根节点放入到队列之中
44 while(rear!=front)
45 {
46 front++;
47 p=pr[front];//用来读取数据
48 cout<<p->data;
49 num++;//用来控制空格的输出,最后一位不用空格
50 if(num<n)
51 cout<<" ";
52 if(p->l!=NULL)
53 {
54 rear++;
55 pr[rear]=p->l;
56 }
57 if(p->r!=NULL)
58 {
59 rear++;
60 pr[rear]=p->r;
61 }
62 }
63 }
64 //个人理解,rear是用来存取数据的,而front是跟着屁股后面来输出的
65 int main()
66 {
67 int N;
68 int j,k,l;
69 cin>>N;
70 n=N;
71 for(j=0;j<N;j++)
72 {
73 cin>>btree[j];
74 }
75 for(j=0;j<N;j++)
76 {
77 cin>>ctree[j];
78 }
79 node *T=creattree(btree,ctree,n);
80 print(T);
81 return 0;
82
83 }

思路:可以多看看数据结构树上的描写进行想,然后用指针,结构体进行理解,暂时还没有理解,但想先存下来然后记记板子

7-10  关于堆的判断

将一系列给定数字顺序插入一个初始为空的小顶堆H[]。随后判断一系列相关命题是否为真。命题分下列几种:

  • x is the rootx是根结点;
  • x and y are siblingsxy是兄弟结点;
  • x is the parent of yxy的父结点;
  • x is a child of yxy的一个子结点。

题目:

代码:

 1 #include<iostream>
2 #include<cmath>
3 #include<cstring>
4 #include<string>
5 #include<cstdio>
6 #include<algorithm>
7 #include<set>
8 #include<queue>
9 #include<stack>
10 #define MAX_VERTS 500
11 using namespace std;
12 int num[10000] = {0};
13 void createHael(int len){
14 for(int i = len/2-1; i >= 0; i--){
15 if(num[i]>num[2*i+1]){
16 int temp = num[i];
17 num[i] = num[2*i+1];
18 num[2*i+1] = temp;
19 if(2*(2*i+1)+1<len&&num[2*i+1]>num[2*(2*i+1)+1]||2*(2*i+1)+2<len&&num[2*i+1]>num[2*(2*i+1)+2]){
20 createHael(len);
21 }
22 }
23 if(num[i]>num[2*i+2]){
24 int temp = num[i];
25 num[i] = num[2*i+2];
26 num[2*i+2] = temp;
27 if(2*(2*i+2)+1<len&&num[2*i+2]>num[2*(2*i+2)+1]||2*(2*i+2)+2<len&&num[2*i+2]>num[2*(2*i+2)+2]){
28 createHael(len);
29 }
30 }
31 // for(int j = 0; j < len; j++){
32 // cout << num[j] << " ";
33 // }
34 // cout << endl;
35 }
36 }
37
38 int find(int t,int n){
39 for(int i = 0; i < n; i++){
40 if(num[i]==t){
41 return i;
42 }
43 }
44 }
45 int main(){
46 int n, m, a, b;
47 string s1,s2,s3,s4,s5,s6;
48 cin >> n >> m;
49 for(int i = 0; i < n; i++){
50 cin >> num[i];
51 createHael(i);
52 }
53
54 for(int i = 0; i < m; i++){
55 cin >> a >> s1;
56 if(s1=="and"){
57 cin >> b >> s2 >> s3;
58 if(ceil(find(a,n)*1.0/2)-1==ceil(find(b,n)*1.0/2)-1){
59 cout << "T" << endl;
60 }else{
61 cout << "F" << endl;
62 }
63 }else{
64 cin >> s2;
65 if(s2=="a"){
66 cin >> s3 >> s4 >> b;
67 if(ceil(find(a,n)*1.0/2)-1==find(b,n)){
68 cout << "T" << endl;
69 }else{
70 cout << "F" << endl;
71 }
72 }else{
73 cin >> s3;
74 if(s3=="root"){
75 if(find(a,n)==0){
76 cout << "T" << endl;
77 }else{
78 cout << "F" << endl;
79 }
80 }else{
81 cin >> s4 >> b;
82 if(ceil(find(b,n)*1.0/2)-1==find(a,n)){
83 cout << "T" << endl;
84 }else{
85 cout << "F" << endl;
86 }
87 }
88 }
89 }
90 }
91 return 0;
92 }

思路:先理解小根堆是什么,然后用二叉树下标的关系,用本下标i和i/2进行比较,多次进行比较,直到不能比较,或者本来就是这个位置最大

QFNU-11.08training的更多相关文章

  1. 地区sql

    /*Navicat MySQL Data Transfer Source Server : localhostSource Server Version : 50136Source Host : lo ...

  2. WinForm 天猫2013双11自动抢红包【源码下载】

    1. 正确获取红包流程 2. 软件介绍 2.1 效果图: 2.2 功能介绍 2.2.1 账号登录 页面开始时,会载入这个网站:https://login.taobao.com/member/login ...

  3. C++11特性——变量部分(using类型别名、constexpr常量表达式、auto类型推断、nullptr空指针等)

    #include <iostream> using namespace std; int main() { using cullptr = const unsigned long long ...

  4. CSS垂直居中的11种实现方式

    今天是邓呆呆球衣退役的日子,在这个颇具纪念意义的日子里我写下自己的第一篇博客,还望前辈们多多提携,多多指教! 接下来,就进入正文,来说说关于垂直居中的事.(以下这11种垂直居中的实现方式均为笔者在日常 ...

  5. C++ 11 多线程--线程管理

    说到多线程编程,那么就不得不提并行和并发,多线程是实现并发(并行)的一种手段.并行是指两个或多个独立的操作同时进行.注意这里是同时进行,区别于并发,在一个时间段内执行多个操作.在单核时代,多个线程是并 ...

  6. CSharpGL(11)用C#直接编写GLSL程序

    CSharpGL(11)用C#直接编写GLSL程序 +BIT祝威+悄悄在此留下版了个权的信息说: 2016-08-13 由于CSharpGL一直在更新,现在这个教程已经不适用最新的代码了.CSharp ...

  7. ABP(现代ASP.NET样板开发框架)系列之11、ABP领域层——仓储(Repositories)

    点这里进入ABP系列文章总目录 基于DDD的现代ASP.NET开发框架--ABP系列之11.ABP领域层——仓储(Repositories) ABP是“ASP.NET Boilerplate Proj ...

  8. C++11 shared_ptr 智能指针 的使用,避免内存泄露

    多线程程序经常会遇到在某个线程A创建了一个对象,这个对象需要在线程B使用, 在没有shared_ptr时,因为线程A,B结束时间不确定,即在A或B线程先释放这个对象都有可能造成另一个线程崩溃, 所以为 ...

  9. C++11网络编程

    Handy是一个简洁优雅的C++11网络库,适用于linux与Mac平台.十行代码即可完成一个完整的网络服务器. 下面是echo服务器的代码: #include <handy/handy.h&g ...

  10. 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(11)-系统日志和异常的处理①

    系列目录 系统需要越来越自动化,我们需要引入日志记录和异常捕获管理员的操作记录需要被记录,看出哪些模块是频繁操作,分析哪些是不必要的功能,哪些是需要被优化的.系统的异常需要被捕获,而不是将系统出错显示 ...

随机推荐

  1. 【死磕JVM】一道面试题引发的“栈帧”!!!

    前言 最近小农的朋友--小勇在找工作,开年来金三银四,都想跳一跳,找个踏(gao)实(xin)点的工作,这不小勇也去面试了,不得不说,现在面试,各种底层各种原理,层出不穷,小勇就遇上了这么一道面试题, ...

  2. JS逆向-抠代码的第四天【手把手学会抠代码】

    今天是md5巩固项目,该项目比昨天的复杂一些,但方法思路是一样的. 今天的目标:https://www.webportal.top/ 打开网站,填入账号密码(密码项目以123456做测试).点击登录抓 ...

  3. linux软件管理之yum管理操作软件包

    什么是rpm 1.1`RPM` 全称 `RedHat Package Manager` 缩写,由红帽开发用于软件包的安装.升级.卸载与查询. 1.2rpm包名组成部分 `RPM` 包命名以-将软件分成 ...

  4. Java进阶专题(二十七) 将近2万字的Dubbo原理解析,彻底搞懂dubbo (下)

    ...接上文 服务发现 服务发现流程 整体duubo的服务消费原理 Dubbo 框架做服务消费也分为两大部分 , 第一步通过持有远程服务实例生成Invoker,这个Invoker 在客户端是核心的远程 ...

  5. Hi3516如何连接Wifi(二)

    目录: 一.总体思路 二.启动Daemon 三.作者文章合集 书承上回(Hi3516如何连接Wifi(一)),上一篇聊了一下怎样在Hi3516中用wpa_supplicant连接到Wifi热点,本文讲 ...

  6. .NET Core 环境变量详解

    一.概述 软件从开发到正式上线,在这个过程中我们会分为多个阶段,通常会有开发.测试.以及上线等.每个阶段对应的环境参数配置我们会使用不同的参数.比如数据库的连接字符串,开发环境一般我们都是连接的测试库 ...

  7. pgrep - 命令

    pgrep 命令格式:pgrep [选项] [模式] 选项 含义 -d <string> 指定输出分隔符 -l PID和进程名称 -a 列出PID和完整的命令行 -v 取反 -c 统计进程 ...

  8. Androi Studio 之 RelativeLayout

    RelativeLayout简介 •基本属性 •根据父容器定位 •父容器定位属性示意图 •根据兄弟组件定位 •根据兄弟组件定位 •margin(偏移) •padding(填充) •margin与pad ...

  9. AI数学基础之:确定图灵机和非确定图灵机

    目录 简介 图灵机 图灵机的缺点 等效图灵机 确定图灵机 非确定图灵机 简介 图灵机是由艾伦·麦席森·图灵在1936年描述的一种抽象机器,它是人们使用纸笔进行数学运算的过程的抽象,它肯定了计算机实现的 ...

  10. django+x-admin管理后台模板开发管理后台案例(设计部分)

    使用django+x-admin管理后台模板搭建管理后台 一.环境需求 1.django:3.1 2.python:3.7 3.x-admin:2.2 4.pycharm:2020.3.2 5.ubu ...