【笔试练习】深信服校园招聘c/c 软件开发H卷

题目链接

一、填空题

  1. 如图所示,平面上有两条平行的线段,上面的线段有A0~A3 4个点,下面的线段有B0到B5 6个点,现在需要把所有的点都连接起来,有如下约束:

    每个端点,都至少有一条到另一平行线上端点的连线;
    连线之间不能有交叉(除了端点,线与线之间不能有连接的地方);

    请问,总共有多少种连法?
    在这里插入图片描述

    答案:231

二、编程题

1. 访问权限

题目
JSON是一种可以用来保存配置的数据格式,其结构为树状。JSON中某个子节点的位置可以JSON路径的形式表示,JSON路径类似UNIX文件路径,以’/'分隔父子节点名。JSON路径中不会出现空格。
如下JSON值中
mem – daemons – findme
| |- waccd
|
|- apps – appd

findme子节点的JSON路径为: /mem/daemons/findme
appd子节点的JSON路径为:/mem/apps/appd
waccd子节点的JSON路径为:/mem/daemons/waccd
有一个列表用来描述各JSON子节点是否允许用户编辑。如下:
Y /mem/daemons/findme
N /mem/daemons
Y /mem

如果有设置用户对某个子节点的权限,则实际权限为该设定权限,否则继承其父节点的可访问性,对根节点的默认访问权限为N。

输入描述
第一行为一个正整数N,表示接下来有N行数据(0 < N < 100)
第2行到第N+1行,为字符串Path,表示待检查访问权限的JSON路径。
第N+2行为一个正整数T,表示接下来有T行数据(0 < T < 1000)
接下来会有T行数据,格式为"权限 JSON路径"。
权限有两种取值:Y和N
JSON路径最大长度为256
输出描述
输出“权限”,权限表示该节点的实际访问权限。
示例1
输入例子:
1
/mem/total
3
Y /mem/daemons/findme
N /mem/daemons
Y /mem

输出例子:
Y

思路——前缀树

将字符串 /mem/start拆分成 mem、start 两单词, 每个单词为一个前缀。

  • 前缀树的属性

    • 当前文件夹是否有权限
    • 当前文件夹是否是继承父目录的权限
    • 当前文件夹的子目录
    • 当前文件夹的名字
  • 前缀树的操作

    • 插入
    • 查询
    • 更新所有文件夹的权限信息
  • 主程序读入所有信息

    • 将待查询的信息,先存在一个 vector 中
    • 将其余信息用于构建前缀树
  • 构建前缀树的过程

    • vector<string> str 保存路径的名字信息(利用函数拆分字符串)
    • 检查map中是否有 str[i] 这个文件夹的名字, 如果没有, 则创建一个文件夹,并赋予父目录的权限
    • node 指向 map[str[i]] 这个节点
  • 查询前缀树的过程:

    • 逐个判断path 中的名字是否在前缀树出现
    • 如果没有出现,则返回当前 node 的权限

代码:

#include<iostream>
#include<vector>
#include<map>
#include<unordered_map>
using namespace std;class Trie {
public:bool hava_Authority = false; bool isInherient = true; // 当前节点的权限是不是继承父节点的unordered_map<string, Trie*> ls; // 孩子节点string name;Trie(bool au, string str) {hava_Authority = au; name = str;}Trie() {}void insert(bool au, vector<string> str) {if (str.empty()) { this->isInherient = false;this->hava_Authority = true;return;}Trie* node = this; // 当前节点(作为父节点)for (int i = 0; i < str.size(); i++) {// 在当前节点的孩子没有找到,说明目前没有该路径,需要新建节点if (node->ls.find(str[i]) == node->ls.end()) {Trie* tmp = new Trie(node->hava_Authority, str[i]); // 继承父节点的权限node->ls.insert(make_pair(str[i], tmp)); // umap 的插入语句}// 已经存在该路径,更新当前节点的下一个访问位置node = node->ls.find(str[i])->second;}// 遍历完 str,就可以更新最后一个节点的权限if (node->isInherient) node->hava_Authority = au; // 记录新的权限node->isInherient = false; // 由于最后一个节点肯定有自己的权限,所以标记为非继承}bool query(vector<string> str) {Trie* node = this;for (int i = 0; i < str.size(); i++) {// 如果在下一层找不到,说明当前层就是最终层if (node->ls.find(str[i]) == node->ls.end()) {break;}// 如果在孩子节点能找到下一层,就递归查询node = node->ls.find(str[i])->second;}// 返回当前层的权限return node->hava_Authority;}// 权限更新void update() {Trie* node = this;for (auto it = node->ls.begin(); it != node->ls.end(); it++) {if (it->second->isInherient) { // 是继承,此时权限是父节点的权限node->ls[it->first]->hava_Authority = node->hava_Authority;}node->ls[it->first]->update(); // 递归更新儿子}}
};vector<string> split(string str) {str += "/"; // 在末尾加上 '/' ,遇到最后一个字符也不需要特殊处理str = str.substr(1); // 跳过第一个 '/' 开始遍历vector<string> res;string tmp;for (int i = 0; i < str.size(); i++) {if (str[i] == '/') {if (tmp.size()) res.push_back(tmp);continue;}tmp += str[i];}return res;
}int main() {Trie* root = new Trie();int n;cin >> n;vector<vector<string>> query;while (n--) {string t;cin >> t;query.push_back(split(t));}cin >> n;string a, b;while (n--) {cin >> a >> b;if (a == "Y") {root->insert(true, split(b));}else {root->insert(false, split(b));}}// 插入结束后,对所有节点进行权限更新root->update();// 查询权限for (int i = 0; i < query.size(); i++) {if (root->query(query[i])) {cout << "Y\n";}else {cout << "N\n";}}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/415748.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HTML+CSS+Query实现二级菜单

在网页设计中&#xff0c;导航菜单是非常重要的部分之一&#xff0c;尤其是具有二级下拉菜单的导航栏&#xff0c;可以提升用户体验。本文将通过HTML、CSS和jQuery实现一个具有二级菜单标题的导航栏&#xff0c;并详细讲解每一步的实现过程。 <!DOCTYPE html> <html …

TS 学习(一)

如果我们在 ts 中写 不用运行就能在文件中报错 ts 是一种静态类型的检查 能将运行时出现的错误前置 一般不用 命令行编译 ts 转换成 js 将中文转码 tsc index&#xff08;.ts&#xff09; 输入命令生成 配置文件 能在中间进行 配置转换成 js 的哪个规范 es5 还是 6 和其它转…

JavaScript编程语言的学习

一、JavaScript介绍 JavaScript 是一种轻量级的脚本语言。所谓“脚本语言”&#xff0c;指的是它不具备开发操作系统的能力&#xff0c;而是只用来编写控制其他大型应用程序的“脚本”。 JavaScript 是一种嵌入式&#xff08;embedded&#xff09;语言。它本身提供的核心语法不…

数分基础(06)商业分析四种类型简介

文章目录 1. 商业分析2. 四种类型2.1 描述性分析和诊断性分析2.1.1 加载Global_Superstore数据集2.1.2 描述性分析2.1.3 诊断性分析2.1.4 再进一步各地区的订单数量和平均订单金额按客户群体分析销售额和利润折扣率和利润产品类别和子类别的销售和利润 本小节小结 2.2 销售预测…

在众多编程工具中,哪一个最能提高你的生产力?

随着软件开发行业的快速发展&#xff0c;开发者们需要使用多种工具来管理代码、调试应用程序、测试功能、以及处理数据库操作。每一个环节都可能会影响到整个项目的进展和最终质量&#xff0c;因此选择合适的工具对于提高工作效率至关重要。在这篇文章中&#xff0c;我将从开发…

VMware16安装Win11虚拟机全步骤

目录 准备工作下载镜像安装镜像开启虚拟机安装虚拟机安装Win11成功 准备工作 1、虚拟机&#xff1a;VMware16.2.1&#xff08;建议使用VMware16版本&#xff0c;15可能不兼容&#xff09; 2、Windows11镜像 下载镜像 1、浏览器打开网址&#xff1a;I tell you 可以看到有三…

坐牢第三十四天(c++)

一.作业 1.栈的手写 #include <iostream> using namespace std; // 封装一个栈 class stcak { private:int *data; //int max_size; // 最大容量int top; // 下标 public:// 无参构造函数stcak();// 有参构造函数stcak(int size);// 拷贝构造函数stcak(const s…

MySQL数据库增删查改(基础)CRUD

CRUD 即增加 (Create) 、查询 (Retrieve) 、更新 (Update) 、删除 (Delete) 四个单词的首字母缩写。 1. 新增&#xff08;Create&#xff09; 1.1单行数据&#xff08;全列插入&#xff09; 比如说&#xff1a;创建一张学生表&#xff0c;有姓名&#xff0c;学号。插入两个学…

什么是科学碳目标(SBTI认证)

科学碳目标&#xff08;SBTI认证&#xff09;&#xff0c;这一绿色发展的璀璨明珠&#xff0c;是企业迈向可持续未来的重要里程碑。它不仅是全球环境信息研究中心(CDP)、联合国全球契约组织(UNGC)、世界资源研究所(WRI)与世界自然基金会(WWF)共同铸就的智慧结晶&#xff0c;更是…

一款实用的浏览器插件,关闭登录提示框一键复制代码

codebox插件是一款面向开发者和技术爱好者的浏览器插件&#xff0c;旨在优化用户的浏览和学习体验。该插件支持多个技术网站&#xff0c;包括CSDN、知乎、简书、脚本之家、博客园、51CTO博客和php中文网等。 主要功能包括&#xff1a; 免登录一键复制代码&#xff1a;用户无需…

Two to One——C语言提高题【7 kyu】

一、原题 链接&#xff1a;Training on Two to One | Codewars Take 2 strings s1 and s2 including only letters from a to z. Return a new sorted string (alphabetical ascending), the longest possible, containing distinct letters - each taken only once - coming…

书生大模型实战营基础(3)——LangGPT结构化提示词编写实践

目录 0、基础知识 1、准备 1.1环境配置 1.2创建项目路径 2、模型部署 2.1获取模型 2.2部署模型为OpenAI server 3.提示工程(Prompt Engineering) 3.1 什么是Prompt 3.2 什么是提示工程 3.3 提示设计框架 4、任务 4.1利用LangGPT优化提示词 0、基础知识 Prompt&…

C++程序调用SetWindowsHookEx全局拦截键盘按键消息和窗口消息的Hook实例分享

目录 1、Hook与Hook过程函数 2、SetWindowsHookEx函数说明 3、Hook实例1 - 使用SetWindowsHookEx在程序中拦截键盘消息 4、Hook实例2 - 使用SetWindowsHookEx在程序中拦截某个窗口的消息 5、最后 C软件异常排查从入门到精通系列教程&#xff08;专栏文章列表&#xff0c;欢…

wsl下将Ubuntu从c盘移动到其他盘

一、概述 因为自己的C盘内存不足&#xff0c;加上之后需要在Ubuntu下面下载许多的内容和东西&#xff0c;需要将其移动到d盘上面&#xff0c;这样可以拥有更大的空间。这里记载了一下自己的操作过程。 二、具体步骤 &#xff08;一&#xff09;过程 1.查看当前系统中wsl分发版…

Hi3061M开发板初测——点亮小灯

目录 前言环境配置点亮led源码IDA集成了串口监视器最后下载到开发板中运行 前言 海思MCU体验官活动&#xff0c;Hi3061M开发板到手后&#xff0c;配置环境初步测试点亮小灯。 环境配置 环境配置按照gitee提供的redeme一步一步来配置起来很顺利。具体可自行查阅&#xff1a;环境…

Python机器学习——人脸性别识别

一、选题背景 人脸识别技术是模式识别和计算机视觉领域最富挑战性的研究课题之一&#xff0c;也是近年来的研究热点&#xff0c;人脸性别识别作为人脸识别技术的重要组成部分也受到了广泛地关注。人脸性别识别就是向计算机输入人脸图像&#xff0c;经过某种方法或运算&#xff…

springnboot +uniapp汽车租赁系统

springnboot uniapp汽车租赁系统 手机移动端&#xff1a;主页&#xff0c;租赁汽车展示&#xff0c;汽车租赁&#xff0c;我的租赁记录&#xff0c;还车记录&#xff0c;注册登录&#xff0c;修改个人资料 PC端管理后台&#xff1a;公告管理&#xff0c;用户管理&#xff0c;…

【链表】环形链表

环形链表 环形链表I题目思路讲解代码书写拓展问题 环形链表II题目题目解析思路讲解代码书写 环形链表I 题目 题目链接: 环形链表 思路讲解 对于探究一个线性结构是否有环, 最经典的做法就是快慢指针法. 我们定义两个指针, 一个一次走两步, 一个一次走一步, 走完后判断两个是…

虚幻引擎VR游戏开发01 | VR设备和术语

四款Unreal Engine默认配套按键映射的VR设备 IMC按键映射 Oculus Touch (R) Grip Axis: 代表Oculus Rift或Quest设备的右手控制器的抓握轴输入。Valve Index (R) Grip Axis: 代表Valve Index设备的右手控制器的抓握轴输入。Vive (R) Grip: 代表HTC Vive设备的右手控制器的抓握…

chrome 插件开发入门

1. 介绍 Chrome 插件可用于在谷歌浏览器上控制当前页面的一些操作&#xff0c;可自主控制网页&#xff0c;提升效率。 平常我们可在谷歌应用商店中下载谷歌插件来增强浏览器功能&#xff0c;作为开发者&#xff0c;我们也可以自己开发一个浏览器插件来配合我们的日常学习工作…