习题5-8 图书管理习题(Borrowers,ACM/ICPC World Finals 1994, UVa230)

2024-04-13 03:32

本文主要是介绍习题5-8 图书管理习题(Borrowers,ACM/ICPC World Finals 1994, UVa230),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原题链接:https://vjudge.net/problem/UVA-230
分类:STL综合
备注:中级模拟
分析:按题目意思来模拟就可以了,但是排序有点麻烦…
代码如下:

#include<iostream>
#include<string>
#include<vector>
#include<map>
#include<set>
#include<algorithm>
using namespace std;
string line, mingz, zuoz;
struct BOOK
{string name, aut;bool operator < (BOOK b){if (aut == b.aut)return name < b.name;return aut < b.aut;}
};
vector<BOOK>book;
vector<int>flag;
int main(void)
{while (getline(cin, line)){if (line[0] == 'E')break;for (int pos = 1; pos < line.length(); pos++){if (line[pos] == '\"')mingz.assign(line, 0, pos + 1);if (line[pos] == 'b' && line[pos + 1] == 'y' && line[pos + 2] == ' '){zuoz.assign(line, pos + 3, line.length() - pos - 3);break;}}book.push_back(BOOK{ mingz, zuoz });flag.push_back(0);}sort(book.begin(), book.end());map<string, int>f;for (int xb = 0; xb != book.size(); ++xb)f[book[xb].name] = xb;vector<int>ret;while (getline(cin, line)){if (line[0] == 'E')break;if (line[0] == 'S'){sort(ret.begin(), ret.end());for (int i = 0; i != ret.size(); i++){int before;for (before = ret[i] - 1; before >= 0; before--)if (!flag[before])break;if (before == -1)cout << "Put " << book[ret[i]].name << " first\n";else cout << "Put " << book[ret[i]].name << " after " << book[before].name << "\n";flag[ret[i]] = 0;}ret.clear();cout << "END\n";}else{mingz.assign(line, 7, line.length() - 7);if (line[0] == 'B')flag[f[mingz]] = 1;else if (line[0] == 'R')ret.push_back(f[mingz]);}}return 0;
}

这篇关于习题5-8 图书管理习题(Borrowers,ACM/ICPC World Finals 1994, UVa230)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/899025

相关文章

nvm如何切换与管理node版本

《nvm如何切换与管理node版本》:本文主要介绍nvm如何切换与管理node版本问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录nvm切换与管理node版本nvm安装nvm常用命令总结nvm切换与管理node版本nvm适用于多项目同时开发,然后项目适配no

Redis实现RBAC权限管理

《Redis实现RBAC权限管理》本文主要介绍了Redis实现RBAC权限管理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1. 什么是 RBAC?2. 为什么使用 Redis 实现 RBAC?3. 设计 RBAC 数据结构

mac安装nvm(node.js)多版本管理实践步骤

《mac安装nvm(node.js)多版本管理实践步骤》:本文主要介绍mac安装nvm(node.js)多版本管理的相关资料,NVM是一个用于管理多个Node.js版本的命令行工具,它允许开发者在... 目录NVM功能简介MAC安装实践一、下载nvm二、安装nvm三、安装node.js总结NVM功能简介N

SpringBoot中使用 ThreadLocal 进行多线程上下文管理及注意事项小结

《SpringBoot中使用ThreadLocal进行多线程上下文管理及注意事项小结》本文详细介绍了ThreadLocal的原理、使用场景和示例代码,并在SpringBoot中使用ThreadLo... 目录前言技术积累1.什么是 ThreadLocal2. ThreadLocal 的原理2.1 线程隔离2

Linux内存泄露的原因排查和解决方案(内存管理方法)

《Linux内存泄露的原因排查和解决方案(内存管理方法)》文章主要介绍了运维团队在Linux处理LB服务内存暴涨、内存报警问题的过程,从发现问题、排查原因到制定解决方案,并从中学习了Linux内存管理... 目录一、问题二、排查过程三、解决方案四、内存管理方法1)linux内存寻址2)Linux分页机制3)

高效管理你的Linux系统: Debian操作系统常用命令指南

《高效管理你的Linux系统:Debian操作系统常用命令指南》在Debian操作系统中,了解和掌握常用命令对于提高工作效率和系统管理至关重要,本文将详细介绍Debian的常用命令,帮助读者更好地使... Debian是一个流行的linux发行版,它以其稳定性、强大的软件包管理和丰富的社区资源而闻名。在使用

SpringBoot使用minio进行文件管理的流程步骤

《SpringBoot使用minio进行文件管理的流程步骤》MinIO是一个高性能的对象存储系统,兼容AmazonS3API,该软件设计用于处理非结构化数据,如图片、视频、日志文件以及备份数据等,本文... 目录一、拉取minio镜像二、创建配置文件和上传文件的目录三、启动容器四、浏览器登录 minio五、

IDEA中的Kafka管理神器详解

《IDEA中的Kafka管理神器详解》这款基于IDEA插件实现的Kafka管理工具,能够在本地IDE环境中直接运行,简化了设置流程,为开发者提供了更加紧密集成、高效且直观的Kafka操作体验... 目录免安装:IDEA中的Kafka管理神器!简介安装必要的插件创建 Kafka 连接第一步:创建连接第二步:选

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<