- 【学习】《算法图解》第七章学习笔记:树
程序员
前言在前面的章节中,我们学习了数组、链表、散列表等基本数据结构,以及一些基础算法。本章将介绍一种非常重要的数据结构——树(Tree),特别是二叉搜索树(BinarySearchTree)。树结构在计算机科学中应用广泛,从文件系统到数据库再到人工智能,都能看到树的身影。《算法图解》第七章深入浅出地介绍了树的基本概念、实现和应用,帮助读者理解这一关键数据结构。一、树的基本概念(一)什么是树树是一种分层
- 【学习】《算法图解》第七章学习笔记:树
自学也学好编程
程序人生
前言在前面的章节中,我们学习了数组、链表、散列表等基本数据结构,以及一些基础算法。本章将介绍一种非常重要的数据结构——树(Tree),特别是二叉搜索树(BinarySearchTree)。树结构在计算机科学中应用广泛,从文件系统到数据库再到人工智能,都能看到树的身影。《算法图解》第七章深入浅出地介绍了树的基本概念、实现和应用,帮助读者理解这一关键数据结构。一、树的基本概念(一)什么是树树是一种分层
- PAT A 1043 Is It a Binary Search Tree
cwn_
算法c++数据结构图论
ABinarySearchTree(BST)isrecursivelydefinedasabinarytreewhichhasthefol‐lowingproperties:•Theleftsubtreeofanodecontainsonlynodeswithkeyslessthanthenode’skey.•Therightsubtreeofanodecontainsonlynodeswithk
- 使用 pip 命令下载 whl离线安装包、安装
三希
pip
使用pip命令直接从线上下载whl离线安装包并转存到离线环境的过程实际上是分两步进行的:第一步:在线环境下载whl包bash#在具有网络连接的环境中pipdownload--only-binary=:all:--wheel--platform--python-version这里的参数说明::需要下载的Python包名称。--only-binary=:all::只下载二进制包(即whl文件)。--w
- MongoDB与Redis有哪些区别
相遇在春风里
经验分享
MongoDB和Redis是两种不同类型的数据库,它们存在以下区别:一、数据模型MongoDBMongoDB是一个文档型数据库,它使用BSON(BinaryJSON)格式存储数据。数据以类似JSON的文档形式组织,每个文档可以有不同的结构(即模式自由)。例如,在一个存储用户信息的集合中,一个用户文档可能包含姓名、年龄、地址等字段,而另一个用户文档可能还包含额外的兴趣爱好字段。这种数据模型非常适合处
- 谷歌地图的3d街景使用的是什么数据格式?
奇树谦
experience3d三维显示
文章目录一、3D街景(StreetView)1.图像部分2.元数据(Metadata)️二、3D城市模型(GoogleEarth或Maps的倾斜摄影模型)1.模型部分2.瓦片划分(TilingSystem)3.材质贴图注意与标准格式对比(参考)✅一、Google3DMesh使用的格式(Protobuf+Binary)1.**数据结构**2.**典型组成**✅二、glTF(GLTransmissio
- DPDK之(七)—— support for vhost-user学习笔记
何进哥哥
DPDKvhostDPDK
转地址:http://www.lai18.com/content/1851237.htmlX86体系早期没有在硬件设计上对虚拟化提供支持,因此虚拟化完全通过软件实现。一个典型的做法是通过优先级压缩(RingCompression)和二进制代码翻译(BinaryTranslation)相结合,VMM在特权级ring0,Guest操作系统在非特权级ring1,Guest应用程序在ring3。由于Gue
- 【云原生】Docker 部署 Elasticsearch 9 操作详解
逆风飞翔的小叔
运维Docker部署es9Docker部署esDocker搭建es9Elasticsearch9Docker搭建es
目录一、前言二、Elasticsearch9新特性介绍2.1基于Lucene10重大升级2.2BetterBinaryQuantization(BBQ)2.3ElasticDistributionsofOpenTelemetry(EDOT)2.4LLM可观测性2.5攻击发现与自动导入2.6ES|QL增强2.7语义检索三、基于Docker部署Elasticsearch93.1Elasticsearc
- C语言:进制转换
一、基本概念1.常见进制系统十进制(Decimal):基数为10,使用数字0-9二进制(Binary):基数为2,使用数字0-1八进制(Octal):基数为8,使用数字0-7十六进制(Hexadecimal):基数为16,使用数字0-9和字母A-F2.进制表示方法在C语言中,不同进制的表示方法:十进制:直接写数字,如123八进制:数字前加0,如0123表示八进制的123十六进制:数字前加0x或0X
- python代码判断两棵二叉树是否相同
Data+Science+Insight
数据结构leetcode算法python二叉树
python代码判断两棵二叉树是否相同给定两个二叉树,编写一个函数来校验它们是否相同。如果两个树在结构上相同,并且结点具有相同的值,则认为它们是相同的。判断两个二叉树是否是相同的,相同的依据是二叉树结构相同二叉树对应节点值相同#二叉树基础类#ABinaryTreenodeclassNode:#Utilitytocreatenewnodedef__init__(self,val):self.val=
- 代码随想录day16二叉树4
皮蛋瘦肉粥_121
二叉树数据结构
文章目录513.找树左下角的值112.路径总和113.路径总和II106.从中序与后序遍历序列构造二叉树105.从前序与中序遍历序列构造二叉树513.找树左下角的值题目链接文章讲解/***Definitionforabinarytreenode.*structTreeNode{*intval;*TreeNode*left;*TreeNode*right;*TreeNode():val(0),lef
- 代码随想录day15二叉树3
皮蛋瘦肉粥_121
二叉树
文章目录222.完全二叉树的节点个数110.平衡二叉树257.二叉树的所有路径404.左叶子之和222.完全二叉树的节点个数题目链接文章讲解/***Definitionforabinarytreenode.*structTreeNode{*intval;*TreeNode*left;*TreeNode*right;*TreeNode():val(0),left(nullptr),right(nul
- 二进制安全
关于这个词,解释的应该很多,不管是密码学还是文件什么的,这次想说的是关于代码是二进制安全的,比如这句Redis的字符串表示还应该是二进制安全的:这里的二进制安全是什么意思呢?感觉wiki里这个解释的还是比较清楚的:Binary-safeisacomputerprogrammingtermmainlyusedinconnectionwithstringmanipulatingfunctions.Ab
- 华为高斯数据库的数据类型
ls65535
华为数据库
华为高斯数据库的数据类型国产数据库华为高斯的GaussDB的数据类型华为高斯数据库的数据类型✅一、数值类型(NumericTypes)✅二、字符类型(CharacterTypes)✅三、布尔类型(BooleanType)✅四、日期和时间类型(Date&TimeTypes)✅五、二进制类型(BinaryTypes)✅六、JSON和XML类型✅七、网络类型(NetworkAddressTypes)✅八
- 3.mysql中的bin log
菜鸟也要未来
mysqlmysql数据库
binlog(二进制日志(BinaryLog,简称binlog)是是数据库服务器层面最重要的日志之一,它以记录了所有对数据库内容进行了修改的SQL语句(INSERT,UPDATE,DELETE,CREATETABLE,ALTERTABLE,DROPTABLE,GRANT,REVOKE等)或实际修改的数据行信息,以及语句执行时的元数据(如时间戳、服务器ID等)。1.binlog配置参数可以在mysq
- 微信小程序接口对接实现
过往的时光
java编程微信小程序javabinarywang
本文介绍使用com.github.binarywang实现微信接口对接的方法,主要包括:1)引入4.7.0版本的weixin-java-miniapp和weixin-java-pay依赖包;2)通过配置文件自动加载微信参数;3)自动创建WxMaService和WxPayService的Bean对象;4)实现用户登录授权、获取用户信息和手机号等功能;5)完成微信支付创建、回调处理、发货信息上传和退款
- 数据库存储文件的实现方式
张太行_
数据库
现代数据库不仅可以存储结构化数据(如Excel表格),还能直接存储文件、图片、视频等二进制数据,甚至支持全文检索和版本管理。以下是具体实现方式和应用场景的详解:一、数据库存储文件的3种核心方式1.BLOB类型直接存储(适合小文件)原理:使用BLOB(BinaryLargeObject)或LONGBLOB(MySQL)/VARBINARY(SQLServer)字段直接存储文件二进制内容。示例:--M
- nginx 限制单IP访问频率
skyymrj
nginx
一、限制所有单个ip的访问频率1、http中的配置http{#$limit_conn_zone:限制并发连接数limit_conn_zone$binary_remote_addrzone=one1:10m;#limit_req_zone:请求频率#$binary_remote_addr:以客户端IP进行限制#zone=one:10m:创建IP存储区大小为10M,用来存储访问频率#rate=10r/
- ubuntu执行sudo apt update 出现问题
问题描述:Readingpackagelists...DoneE:Failedtofetchhttps://mirrors.ustc.edu.cn/ubuntu-ports/dists/focal/main/binary-amd64/Packages404NotFound[IP:202.38.95.110443]E:Failedtofetchhttps://mirrors.ustc.edu.cn/
- leetcode:129. 求根节点到叶节点数字之和
呆呆的小鳄鱼
#递归#深搜leetcode算法职场和发展
题目链接129.求根节点到叶节点数字之和-力扣(LeetCode)题目描述解法1:深搜/***Definitionforabinarytreenode.*structTreeNode{*intval;*TreeNode*left;*TreeNode*right;*TreeNode():val(0),left(nullptr),right(nullptr){}*TreeNode(intx):val(
- “最浅”的陷阱:聊聊二叉树最小深度的递归坑点与解法哲学
Echo_Wish
LeetCode极客营算法javascriptlinux
“最浅”的陷阱:聊聊二叉树最小深度的递归坑点与解法哲学一、开篇闲聊:你以为的“最小”,可能是“最大”的误区有时候,算法题像极了人生。明明想找一条“最短的路”,却不小心走进了“最深的坑”。这句话,用来形容二叉树的最小深度(MinimumDepthofBinaryTree)问题,真是再贴切不过了。最小深度是什么?简单说,就是从根节点到最近的叶子节点的路径长度。问题听起来很简单,但一不小心就会犯个经典错
- 98. 验证二叉搜索树(二叉搜索树+判定)
勿忘勿失
#数据结构算法c++
题目链接:98.验证二叉搜索树考查知识:二叉搜索树+判定题意描述:给定一棵二叉树,判断其是否是一个有效的二叉搜索树。思路简析:二叉查找树(BinarySearchTree),(又:二叉搜索树,二叉排序树)它或者是一棵空树,或者是具有下列性质的二叉树:若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值;若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值;中序遍历二叉搜索树,判断是
- 二分查找法--有序表
weixin_44673899
技术二分查找法--有序表
思路:1.定义一个方法,再在main()方法里传入数组和自己想要查找的数。2.二分法适用于有序表,首先将给的target与中间位置比较,相等则查找成功,不相等则在前半段或后半段。大于中间位置数在后半段,小于在前半段。缩小范围继续查找,直到找到为止,循环完毕还没有找到返回负一。代码publicclassBinarySearch{publicstaticvoidmain(Stringargs[]){i
- FPGA基础 -- Verilog语言要素之整型数、实数、字符串
sz66cm
FPGA基础fpga开发
✅一、整型数(Integer)Verilog中的整型值支持如下几种方式表达:1.常规整数格式(literal)10//默认十进制8'd10//8位的十进制108'b1010//8位的二进制8'o12//8位的八进制(12=10)8'hA//8位的十六进制(A=10)2.语法结构说明[位宽]'[进制][数值]位宽:指明宽度,如8'd10是8位进制:b:二进制(binary)o:八进制(octal)d
- 前端系列之:Blob
程序员SKY
前端前端
Blob与二进制什么是二进制?二进制是计算机数据的基本表示形式,只使用0和1两个数字来表示数值。任何类型的数据(无论是文本、图片、音频文件等)都可以通过二进制表示。什么是Blob?全称BinaryLargeObject,二进制类型的大对象。是一种数据类型,用来存储二进制数据。怎么解释JavaScript的数据类型中并没有Blob类型?Blob是用来存储二进制数据的,而二进制又是计算机的基本表示形式
- Mongodb之Objectid
进步哥
数据库mongodb数据库python
文章目录一、Objectid的概述二、Objectid的结构三、Objectid的用途四、Objectid在python中的使用1、生成一个Objectid2、指定生成Objectid3、依据时间来生成Objectid4、obj.binary来生成ObjectId5、判断是否是ObjectId对象五、使用pymong将数据导一、Objectid的概述ObjectID是MongoDB文档的默认主键,
- c++二分查找模板
不止有一席地
c++
//最基本的二分查找算法intbinary_search(int[]nums,inttarget){intleft=0,right=nums.length-1;while(lefttarget){right=mid-1;}elseif(nums[mid]==target){//直接返回returnmid;}}//直接返回return-1;}//寻找左侧边界的二分查找intleft_bound(in
- 解决前端vue项目在linux上,npm install,node-sass 安装失败的问题
_朱志强
前端vue.jslinux
Unabletosavebinary/var/lib/jenkins/workspace/xxx/node_modules/node-sass/vendor/linux-x64-72:Error:EACCES:permissiondenied,mkdir‘/var/lib/jenkins/workspace/x/node_modules/node-sass/vendor’这个是node-sass安
- c++常用算法
一只小青团
算法c++数据结构
目录一.遍历算法1.for_each(起始迭代器,终点迭代器,函数());2.transform(搬运且遍历)二.查找算法1.find`//查找元素2.find_if`//按条件查找元素3.adjacent_find`//查找相邻重复元素4.binary_search`//二分查找法5.count`//统计元素个数6.count_if`//按条件统计元素个数三.排序算法1.sort2random_
- MySQL 类型转换与加密函数深度解析
步行cgn
数据库mysqlandroid数据库
MySQL类型转换与加密函数深度解析一、类型转换函数详解1.显式类型转换CAST函数CAST(expressionAStype)支持类型:BINARY,CHAR,DATE,DATETIME,TIME,DECIMAL,SIGNED[INTEGER],UNSIGNED[INTEGER]示例:SELECTCAST('2023-08-15'ASDATE);--2023-08-15SELECTCAST(12
- JAVA基础
灵静志远
位运算加载Date字符串池覆盖
一、类的初始化顺序
1 (静态变量,静态代码块)-->(变量,初始化块)--> 构造器
同一括号里的,根据它们在程序中的顺序来决定。上面所述是同一类中。如果是继承的情况,那就在父类到子类交替初始化。
二、String
1 String a = "abc";
JAVA虚拟机首先在字符串池中查找是否已经存在了值为"abc"的对象,根
- keepalived实现redis主从高可用
bylijinnan
redis
方案说明
两台机器(称为A和B),以统一的VIP对外提供服务
1.正常情况下,A和B都启动,B会把A的数据同步过来(B is slave of A)
2.当A挂了后,VIP漂移到B;B的keepalived 通知redis 执行:slaveof no one,由B提供服务
3.当A起来后,VIP不切换,仍在B上面;而A的keepalived 通知redis 执行slaveof B,开始
- java文件操作大全
0624chenhong
java
最近在博客园看到一篇比较全面的文件操作文章,转过来留着。
http://www.cnblogs.com/zhuocheng/archive/2011/12/12/2285290.html
转自http://blog.sina.com.cn/s/blog_4a9f789a0100ik3p.html
一.获得控制台用户输入的信息
&nbs
- android学习任务
不懂事的小屁孩
工作
任务
完成情况 搞清楚带箭头的pupupwindows和不带的使用 已完成 熟练使用pupupwindows和alertdialog,并搞清楚两者的区别 已完成 熟练使用android的线程handler,并敲示例代码 进行中 了解游戏2048的流程,并完成其代码工作 进行中-差几个actionbar 研究一下android的动画效果,写一个实例 已完成 复习fragem
- zoom.js
换个号韩国红果果
oom
它的基于bootstrap 的
https://raw.github.com/twbs/bootstrap/master/js/transition.js transition.js模块引用顺序
<link rel="stylesheet" href="style/zoom.css">
<script src=&q
- 详解Oracle云操作系统Solaris 11.2
蓝儿唯美
Solaris
当Oracle发布Solaris 11时,它将自己的操作系统称为第一个面向云的操作系统。Oracle在发布Solaris 11.2时继续它以云为中心的基调。但是,这些说法没有告诉我们为什么Solaris是配得上云的。幸好,我们不需要等太久。Solaris11.2有4个重要的技术可以在一个有效的云实现中发挥重要作用:OpenStack、内核域、统一存档(UA)和弹性虚拟交换(EVS)。
- spring学习——springmvc(一)
a-john
springMVC
Spring MVC基于模型-视图-控制器(Model-View-Controller,MVC)实现,能够帮助我们构建像Spring框架那样灵活和松耦合的Web应用程序。
1,跟踪Spring MVC的请求
请求的第一站是Spring的DispatcherServlet。与大多数基于Java的Web框架一样,Spring MVC所有的请求都会通过一个前端控制器Servlet。前
- hdu4342 History repeat itself-------多校联合五
aijuans
数论
水题就不多说什么了。
#include<iostream>#include<cstdlib>#include<stdio.h>#define ll __int64using namespace std;int main(){ int t; ll n; scanf("%d",&t); while(t--)
- EJB和javabean的区别
asia007
beanejb
EJB不是一般的JavaBean,EJB是企业级JavaBean,EJB一共分为3种,实体Bean,消息Bean,会话Bean,书写EJB是需要遵循一定的规范的,具体规范你可以参考相关的资料.另外,要运行EJB,你需要相应的EJB容器,比如Weblogic,Jboss等,而JavaBean不需要,只需要安装Tomcat就可以了
1.EJB用于服务端应用开发, 而JavaBeans
- Struts的action和Result总结
百合不是茶
strutsAction配置Result配置
一:Action的配置详解:
下面是一个Struts中一个空的Struts.xml的配置文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
&quo
- 如何带好自已的团队
bijian1013
项目管理团队管理团队
在网上看到博客"
怎么才能让团队成员好好干活"的评论,觉得写的比较好。 原文如下: 我做团队管理有几年了吧,我和你分享一下我认为带好团队的几点:
1.诚信
对团队内成员,无论是技术研究、交流、问题探讨,要尽可能的保持一种诚信的态度,用心去做好,你的团队会感觉得到。 2.努力提
- Java代码混淆工具
sunjing
ProGuard
Open Source Obfuscators
ProGuard
http://java-source.net/open-source/obfuscators/proguardProGuard is a free Java class file shrinker and obfuscator. It can detect and remove unused classes, fields, m
- 【Redis三】基于Redis sentinel的自动failover主从复制
bit1129
redis
在第二篇中使用2.8.17搭建了主从复制,但是它存在Master单点问题,为了解决这个问题,Redis从2.6开始引入sentinel,用于监控和管理Redis的主从复制环境,进行自动failover,即Master挂了后,sentinel自动从从服务器选出一个Master使主从复制集群仍然可以工作,如果Master醒来再次加入集群,只能以从服务器的形式工作。
什么是Sentine
- 使用代理实现Hibernate Dao层自动事务
白糖_
DAOspringAOP框架Hibernate
都说spring利用AOP实现自动事务处理机制非常好,但在只有hibernate这个框架情况下,我们开启session、管理事务就往往很麻烦。
public void save(Object obj){
Session session = this.getSession();
Transaction tran = session.beginTransaction();
try
- maven3实战读书笔记
braveCS
maven3
Maven简介
是什么?
Is a software project management and comprehension tool.项目管理工具
是基于POM概念(工程对象模型)
[设计重复、编码重复、文档重复、构建重复,maven最大化消除了构建的重复]
[与XP:简单、交流与反馈;测试驱动开发、十分钟构建、持续集成、富有信息的工作区]
功能:
- 编程之美-子数组的最大乘积
bylijinnan
编程之美
public class MaxProduct {
/**
* 编程之美 子数组的最大乘积
* 题目: 给定一个长度为N的整数数组,只允许使用乘法,不能用除法,计算任意N-1个数的组合中乘积中最大的一组,并写出算法的时间复杂度。
* 以下程序对应书上两种方法,求得“乘积中最大的一组”的乘积——都是有溢出的可能的。
* 但按题目的意思,是要求得这个子数组,而不
- 读书笔记-2
chengxuyuancsdn
读书笔记
1、反射
2、oracle年-月-日 时-分-秒
3、oracle创建有参、无参函数
4、oracle行转列
5、Struts2拦截器
6、Filter过滤器(web.xml)
1、反射
(1)检查类的结构
在java.lang.reflect包里有3个类Field,Method,Constructor分别用于描述类的域、方法和构造器。
2、oracle年月日时分秒
s
- [求学与房地产]慎重选择IT培训学校
comsci
it
关于培训学校的教学和教师的问题,我们就不讨论了,我主要关心的是这个问题
培训学校的教学楼和宿舍的环境和稳定性问题
我们大家都知道,房子是一个比较昂贵的东西,特别是那种能够当教室的房子...
&nb
- RMAN配置中通道(CHANNEL)相关参数 PARALLELISM 、FILESPERSET的关系
daizj
oraclermanfilespersetPARALLELISM
RMAN配置中通道(CHANNEL)相关参数 PARALLELISM 、FILESPERSET的关系 转
PARALLELISM ---
我们还可以通过parallelism参数来指定同时"自动"创建多少个通道:
RMAN > configure device type disk parallelism 3 ;
表示启动三个通道,可以加快备份恢复的速度。
- 简单排序:冒泡排序
dieslrae
冒泡排序
public void bubbleSort(int[] array){
for(int i=1;i<array.length;i++){
for(int k=0;k<array.length-i;k++){
if(array[k] > array[k+1]){
- 初二上学期难记单词三
dcj3sjt126com
sciet
concert 音乐会
tonight 今晚
famous 有名的;著名的
song 歌曲
thousand 千
accident 事故;灾难
careless 粗心的,大意的
break 折断;断裂;破碎
heart 心(脏)
happen 偶尔发生,碰巧
tourist 旅游者;观光者
science (自然)科学
marry 结婚
subject 题目;
- I.安装Memcahce 1. 安装依赖包libevent Memcache需要安装libevent,所以安装前可能需要执行 Shell代码 收藏代码
dcj3sjt126com
redis
wget http://download.redis.io/redis-stable.tar.gz
tar xvzf redis-stable.tar.gz
cd redis-stable
make
前面3步应该没有问题,主要的问题是执行make的时候,出现了异常。
异常一:
make[2]: cc: Command not found
异常原因:没有安装g
- 并发容器
shuizhaosi888
并发容器
通过并发容器来改善同步容器的性能,同步容器将所有对容器状态的访问都串行化,来实现线程安全,这种方式严重降低并发性,当多个线程访问时,吞吐量严重降低。
并发容器ConcurrentHashMap
替代同步基于散列的Map,通过Lock控制。
&nb
- Spring Security(12)——Remember-Me功能
234390216
Spring SecurityRemember Me记住我
Remember-Me功能
目录
1.1 概述
1.2 基于简单加密token的方法
1.3 基于持久化token的方法
1.4 Remember-Me相关接口和实现
- 位运算
焦志广
位运算
一、位运算符C语言提供了六种位运算符:
& 按位与
| 按位或
^ 按位异或
~ 取反
<< 左移
>> 右移
1. 按位与运算 按位与运算符"&"是双目运算符。其功能是参与运算的两数各对应的二进位相与。只有对应的两个二进位均为1时,结果位才为1 ,否则为0。参与运算的数以补码方式出现。
例如:9&am
- nodejs 数据库连接 mongodb mysql
liguangsong
mongodbmysqlnode数据库连接
1.mysql 连接
package.json中dependencies加入
"mysql":"~2.7.0"
执行 npm install
在config 下创建文件 database.js
- java动态编译
olive6615
javaHotSpotjvm动态编译
在HotSpot虚拟机中,有两个技术是至关重要的,即动态编译(Dynamic compilation)和Profiling。
HotSpot是如何动态编译Javad的bytecode呢?Java bytecode是以解释方式被load到虚拟机的。HotSpot里有一个运行监视器,即Profile Monitor,专门监视
- Storm0.9.5的集群部署配置优化
roadrunners
优化storm.yaml
nimbus结点配置(storm.yaml)信息:
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional inf
- 101个MySQL 的调节和优化的提示
tomcat_oracle
mysql
1. 拥有足够的物理内存来把整个InnoDB文件加载到内存中——在内存中访问文件时的速度要比在硬盘中访问时快的多。 2. 不惜一切代价避免使用Swap交换分区 – 交换时是从硬盘读取的,它的速度很慢。 3. 使用电池供电的RAM(注:RAM即随机存储器)。 4. 使用高级的RAID(注:Redundant Arrays of Inexpensive Disks,即磁盘阵列
- zoj 3829 Known Notation(贪心)
阿尔萨斯
ZOJ
题目链接:zoj 3829 Known Notation
题目大意:给定一个不完整的后缀表达式,要求有2种不同操作,用尽量少的操作使得表达式完整。
解题思路:贪心,数字的个数要要保证比∗的个数多1,不够的话优先补在开头是最优的。然后遍历一遍字符串,碰到数字+1,碰到∗-1,保证数字的个数大于等1,如果不够减的话,可以和最后面的一个数字交换位置(用栈维护十分方便),因为添加和交换代价都是1