- Redis系列:Geo 类型赋能亿级地图位置计算
Ly768768
redisbootstrap数据库
1前言我们在篇深刻理解高性能Redis的本质的时候就介绍过Redis的几种基本数据结构,它是基于不同业务场景而设计的:动态字符串(REDIS_STRING):整数(REDIS_ENCODING_INT)、字符串(REDIS_ENCODING_RAW)双端列表(REDIS_ENCODING_LINKEDLIST)压缩列表(REDIS_ENCODING_ZIPLIST)跳跃表(REDIS_ENCODI
- Redis数据结构—跳跃表 skiplist
马卫斌 前端工程师
skiplist
跳跃表(Skiplist)是Redis中用于实现有序集合(SortedSet)的一种高效数据结构。以下是关于Redis中跳跃表(Skiplist)的关键特性和工作原理的概览:基本概念层级结构:跳跃表通过多层次的链表组成,每一层都是下一层的稀疏视图,顶层最快地遍历整个链表,而底层则是完全连通所有节点的传统链表结构。这样的设计使得查询操作能够快速跳过大量不需要检查的元素。有序集合:每个节点(或称为元素
- gdb常用命令
过好每一天的女胖子
linuxgdblinuxgdb
文章目录1、GDB2、常用命令gdb可执行文件名run(r)/start运行程序break/bclear/deletedisable/enabledisplayjumpwhatisinfothreadbacktrace/btnext(n)/nextistep(s)/stepifinishuntilcallsetprint/plistwatch/awatch/rwatchcatch/tcatchxc
- pip list 出现error
BenjaminY
------------问题描述--------------更新到pip19.0.1原来piplist可以正常使用并且返回各个package安装版本又强制安装了一个package的版本然后piplist报了一大堆错,并且pycharm里也看不到包。问题总结为:就是因为强制安装了两个版本生成了一个‘-’开头的文件夹这个文件夹里面没有METADATA这个文件-----------解决方法-------
- pip --upgrade批量更新过期的python库
diniushu8825
pythonshell
今天看了下系统环境,不少python库都有了更新,再用旧版本库可能已经不适合了,就想把所有的库都更新到最新版本。查看系统里过期的python库,可以用pip命令piplist#列出所有安装的库piplist--outdated#列出所有过期的库对于列出的过期库,pip也提供了更新的命令pipinstall--upgrade库名但此命令不支持全局全部库升级。在stackoverflow上有人提供了批
- matplotlib绘图时,不出图。无明显报错
xbqztdjz
matplotlib
可能是matplotlib和numpy冲突,造成这种问题。1.卸载两个库pipuninstallmatplotlibpipuninstallnumpy2.查看anaconda环境中这两个库是否删干净了piplist若出现warning:对warning的理解是之前用命令卸载了两个包,但是这两个包没有卸载干净,在piplist列表中又出现了,这两个操作产生了冲突,就报了warning。解决办法:,进
- iOS 第三方登录
YQ_苍穹
第三方登录原理友盟登录1.在友盟下载SDK下载SDK2.查看如何配置SDK3.将SDK(UMSocial_SDK)拖拽到项目中,然后按照友盟文档做相应的配置:如:修改plist文件,让其支持HTTPS请求为APP瘦身导入依赖框架指明那个应用集成登录在友盟官方文档中直接拷贝,三方登录代码就ok了新浪微博登录SSO授权不跳转到微博登录了,直接授权配置步骤:在上面友盟登录的基础上,将之前下载的SDK里面
- 【附源码】计算机毕业设计Python安卓校园外卖点餐系统ojry5(源码+程序+LW+调试部署)
Python毕设程序设计uniapp
课程设计python开发语言
【附源码】计算机毕业设计Python安卓校园外卖点餐系统ojry5(源码+程序+LW+调试部署)该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程项目运行环境配置:Python3.7.7+Django+Mysql5.7+piplist+HBuilderX(Vscode也行)+uni+Vue+Pychram社区版。项目技术:Django+uni小程序+Python+Mysql等等组成,B
- 安装torch后仍然报错“缺少fbgemm.dll”的解决方法
00S7
python
报错详情C:\Users\1>activatetestC:\Users\1>conda.batactivatetest(test)C:\Users\1>piplistPackageVersion-----------------------------filelock3.13.1fsspec2024.2.0Jinja23.1.3joblib1.4.2MarkupSafe2.1.5mpmath1.3
- 【CSS】CSS之&旋转&动画
Pixel0216
CSScss动画css3
目录iconfont图标的使用进入https://www.iconfont.cn位移旋转转换原点缩放位移&旋转&缩放注意点渐变色动画关键帧鼠标经过暂停逐帧动画多组动画多组动画iconfont图标的使用进入https://www.iconfont.cn添加完成iconfont图标之后点击添加至项目,在项目中就可以看到添加的图标常用的有三种方法,第一种下载至本地第二种生成在线代码复制到相应的文件内第三
- Flowable获取下一个节点审批人和审批组
R-sz
java
@OverridepublicvoidgetNextStepList(StringtaskId,StringprocessInstanceId)throwsIllegalAccessException{//taskService、repositoryService等容器对象获取省略...//存储当前节点的下一环节的所有用户节点ArrayListuserTaskList=newArrayListus
- python 学习积累
Noxi_lumors
python学习
持续更新中感受python的强大之case列举:1.生成的maplist要经过json格式化写入文件,请用python实现这一需求importjsonmap={"name":"张三","age":18,"address":"北京"}list=[]foriinrange(3):list.append(map)withopen('output.json','w',encoding='utf-8')as
- 记录k8s证书过期的证书更新
安顾里
kuberneteskuberneteslinux服务器容器微服务
root@master01:~#kubectlgetnodesE082810:29:54.48148947445memcache.go:265]couldn'tgetcurrentserverAPIgrouplist:Get"https://192.168.91.150:6443/api?timeout=32s":tls:failedtoverifycertificate:x509:certifi
- MacOS Catalina 10.15.7 19H2正式版下载 CLOVER 5022/OC062/PE三用引导支持Intel及AMD双平台原版镜像
黑苹果基地
安装包说明Clover默认配置文件,原则上支持各种机型引导安装。config.plist,技嘉8/9thMB適用主板为ASUS。8/9thMB者,請改用config_asus.plist來安裝引導。更新到。CLOVERv2.5kr5022驱动更新。更新8。liluv1.4.更新5.3。AppleALCv1.更新WhateverGreen.4.3。v1去除,减少禁行发生的机率;增加崩溃的日志信息显示
- Java 中Lambada表达式中双冒号 ::使用总结
何以解忧,唯有..
java开发语言
一、前言双冒号运算操作符是类方法的句柄,lambda表达式的一种简写表达式:person->person.getName();可以替换成:Person::getName表达式:()->newHashMaplist=Arrays.asList("a","b","c");//静态方法引用ClassName::methodNamelist.forEach(Colon::print);//上一行等价于//
- iOS开发之Debug之iOS11相册权限
十万个逗
iOS开发之Debug
背景:升级iOS11后,相册权限发生变化。变化:相册权限需要在info.plist—PropertyList文件中添加NSPhotoLibraryUsageDescription键值对,描述文字不能为空。iOS11之前:访问相册和存储照片到相册(读写权限),需要用户授权,需要添加NSPhotoLibraryUsageDescription。iOS11之后:默认开启访问相册权限(读权限),无需用户授
- requests库
uid68423
python开发语言
一、pycharm导入requests库在终端下输入pipinstallrequests按回车即可导入。如果使用piplist可以查到requests库即导入成功。二、requsets的get请求url为我们要请求的网址,headers用于伪造请求头,有的网址拒绝爬虫访问。##GET#importrequests#url="http://httpbin.org/get"###携带get请求参数,多
- redis启动出错Creating Server TCP listening socket 127.0.0.1:6379: bind: No error
技术帮
启动服务时有时会出现如下错误:[2368]21Apr02:57:05.611#CreatingServerTCPlisteningsocket127.0.0.1:6379:bind:Noerror解决方法:在命令行中运行redis-cli.exe127.0.0.1:6379>shutdownnotconnected>exit然后重新运行redis-server.exeredis.windows.c
- 高德地图SDK Android版开发 8 覆盖物示例2动画
程序喵D
高德地图Android开发android高德地图
高德地图SDKAndroid版开发8覆盖物示例2动画前言动画相关的类和接口帧动画MarkerOptionsAnimation动画Animation类及其子类AnimationTranslateAnimationRotateAnimationAlphaAnimationScaleAnimationAnimationSetMarker动画示例界面布局MapMarkAnimate类常量成员变量初始值创建
- HarmonyOS鸿蒙转场动画概览
PlumCarefree
harmonyos华为
使用原因:提升用户体验,更加流畅丝滑动效设计场景1.特征动效2.转场动效点击滑动翻动夹捏拖拽3.微动效细微动画4.特征动效插画动效动画能力选型系统动画属性动画显示动画转场动画路径动画粒子动画第三方动画资源加载类GIF动画帧动画第三方库LottieSVG动画开发实现视角转换步骤了解系统能力,包括相关的API分析UX设计视角设计动画方案使用动画能力调试和优化例如使用属性动画:.animation例如加
- 【Python】已解决:WARNING: Ignoring invalid distribution -addlepaddle (d:\soft\python36\lib\site-packages)
屿小夏
python开发语言
文章目录一、分析问题背景二、可能出错的原因三、错误代码示例四、正确解决方法五、注意事项已解决:WARNING:Ignoringinvaliddistribution-addlepaddle(d:\soft\python36\lib\site-packages)一、分析问题背景在使用Python进行开发时,有时我们在执行pip命令(如piplist或pipfreeze)查看已安装的Python包时,
- 【GDI+】C++截长图
beibaoke910
windows客户端c++windows开发语言
一、准备1、屏幕截图【GDI+】C++屏幕截图使用BitBlt来进行截图2、强制刷新c++窗口立即刷新重绘截图的时候,有可能由于界面没有及时刷新,导致截到的内容,这时就需要强制立刻刷新重绘InvalidateRect(m_hWnd,NULL,TRUE);UpdateWindow(m_hWnd);二、截长图1、截全屏【不考虑表头、顶部、底部等因素】需求:界面只有一个List控件m_pList,放着数
- Redis是如何避免“数组+链表”的过长问题
龙大.
Redisredis散列表数据库
目录一、扩展和收缩二、使用高质量的哈希函数三、使用跳跃表(skiplist)或其他数据结构四、哈希表分片一、扩展和收缩Redis通过动态调整哈希表的大小来解决“数组+链表”的长度问题,这涉及到两个过程:扩展(Expand)和收缩(Shrink)。扩展:当哈希表的负载因子(loadfactor)超过一个阈值时,Redis会进行扩展操作。负载因子是哈希表已存储的元素数量与哈希表大小的比值。扩展操作包括
- python的for语句有几种写法_Python循环迭代的高效写法,亲测对比让你的代码速度更快...
weixin_39775106
Python的循环迭代有多种写法,我们实际常用的主要是for循环,列表推导,生成器函数和Map函数实现等四种:列表推导式书写形式:[表达式for变量in序列]或者[表达式for变量in列表if条件]multiples=[表达式(i)foriin序列]生成一个名为multiples的列表保存推导结果2.for循环推导书写形式:tmplist=[]foriin序列:templist.append(表达
- js解析IPA,apk,pp文件的包名,版本信息,图片等plist信息
sunny-king
前端技术功能代码前台解析IPA前台解析apkjquery解析pp文件前台解析解析安装包信息
所需文件app-plist-parser.js示例:functionappSelect(){constfiles=document.getElementById('file').files;constparser=newAppInfoParser(files[0]);parser.parse().then(result=>{console.log('appinfo---->',result);co
- 拿捏单链表
林辞忧
数据结构数据结构
目录引言一:链表的定义二:单链表的定义三:单链表的增删查改1.单链表增删查改及遍历的声明注:在测试中创建指向头结点的指针plist2.二级指针应用的说明3.单链表的遍历4.创建节点5.单链表的插入(1)头插(2)尾插(3)任意位置之前插入(4)任意位置之后插入6.单链表的删除(1)头删(2)尾删(3)任意位置删除7.单链表的查找8.单链表的修改四:关于单链表的介绍就到此为止了,青山不改,绿水长流,
- c/c++导出lua绑定
ajt1472580369
luac/c++python
【转载】https://note.youdao.com/share/?id=0f4132271151c4b62f9afb712e8304d9&type=note#/1、在纯C环境下,把C函数注册进Lua环境,理解Lua和C之间可以互相调用的本质2、在cocos2d-x项目里,把纯C函数注册进Lua环境,理解cocos2d-x是怎样创建Lua环境的、以及怎样得到这个环境并继续自定义它3、了解为什么要
- 为什么不用跳表
啄sir.
java
跳表(SkipList)是一种用于实现有序集合的数据结构,它通过在不同层次上建立索引来加速查找操作。虽然跳表在某些情况下能够提供较好的性能,但在实际应用中,并不是所有的场景都适合使用跳表,主要有以下几个原因:1.额外的空间开销:跳表需要维护多层索引以加速查找操作,这会占用额外的内存空间。在存储空间有限的情况下,跳表可能会消耗比较大的空间开销。2.维护成本高:跳表的插入和删除操作需要更新多个层次的索
- android最全的动画讲解
苏金标
android知识点总结android
android的动画一共分为三种,view动画,帧动画,属性动画。View动画什么是view动画,动画的对象只能是view的动画叫做view动画。view动画一共分为四种:TranslateAnimation(平移),ScaleAnimation(缩放),RotateAnimation(旋转),AlphaAnimation(透明度)四种动画。还有一个AnimationSet(组合动画),他们都继承
- 阿里Java技术面试题,我就服这一文!
Java架构007
金三银四跳槽季即将到来,作为Java开发者你开始刷面试题了吗?别急,小编整理了阿里技术面试题,看这一文就够了!阿里面试题目目录技术一面(基础面试题目)技术二面(技术深度、技术原理)项目实战(项目模拟面试)JAVA开发技术常问的问题阿里必会知识阿里面试范畴面试总结文章福利(答案获取)一:阿里技术一面(基础掌握牢固)常用的异常类型?sessionjava锁gc原理hashmaplistlinkarra
- 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