- ACCA F2重要知识:Planning and Control丨ACCA F2微课堂(2)
ACCA学习帮
干货丨拓展丨趣闻丨指南ACCAF2丨文:EstelleACCAF2把管理活动总结为三个词:planning,controlanddecision-making.这里通过举例讲解一下Planningandcontrol.1.Planning(关键词是objective/goalandstrategy)(i)Establishthecompany’sgoal:increaseprofitby20%in
- Unity3d学习笔记
明月海子
Mecanin动画系统.pngNavigation导航系统.pngShader渲染基础.png面向对象六大原则.png策略模式Strategy.png工厂模式Factory产品工厂.png观察者Observer.png结构设计模式总结.png模板方法模式TemplateMethod.png适配器模式Adapter.png外观模式Facade.png职责连模式ChainofResponsibilit
- 名诗我译(伊丽莎白·布朗宁篇)——Sonnets From The Portuguese(34) 葡萄牙的十四行诗 第34首
臻念
译文:真念一思作者:伊丽莎白·布朗宁Withthesameheart,Isaid,I'llanswertheeAsthose,whenthoushaltcallmebymyname--Lo,thevainpromise!Isthesame,thesame,Perplexedandruffledbylife'sstrategy?Whencalledbefore,ItoldhowhastilyIdro
- goleveldb的原理简述(基于golang的goleveldb库)
陈墨1234
golang进阶之路源码学习golang开发语言后端经验分享笔记db
简介goleveldb是基于LSM-Tree实现的针对处理写多读少场景的解决方案,通常用于构建写多读少的存储引擎整体架构图如下基于用户接口层简述原理吧Get,按key查询数据,首先区内存中的数据,如果内存中没有则依次从硬盘中的ldb文件中取得数据。Put,按key更新数据,首先写内存数据,如果大小达到内存存储的阈值,则将immutable替换为memtable,新建一个logfile存储wal日志
- 翻译 Compaction wiki
i_need_job
网址:https://github.com/facebook/rocksdb/wiki/Compaction有道CompactionCompactionalgorithmsconstraintheLSMtreeshape.Theydeterminewhichsortedrunscanbemergedbyitandwhichsortedrunsneedtobeaccessedforareadoper
- recover device type disk copy of database 还不会用!!!!
jnrjian
数据库oracle
ImplementingaDualBackupStrategywithBackupstoDiskandRecoveryAppliance(DocID2154461.1)RMAN-HowtoimplementDualBackupstrategy(DocID3003000.1)ZeroDataLossRecoveryApplianceSoftware-Version12.1.0.1.0andlater
- HBase 源码阅读(四)HBase 关于LSM Tree的实现- MemStore
Such Devotion
hbaselsm-tree数据库
4.MemStore接口Memstore的函数不能并行的被调用。调用者需要持有读写锁,这个的实现在HStore中我们放弃对MemStore中的诸多函数进行查看直接看MemStore的实现类AbstractMemStoreCompactingMemStoreDefaultMemStore4.1三个实现类的使用场景1.AbstractMemStore角色:基础抽象类作用:AbstractMemStor
- 【软件设计】常用设计模式--策略模式
秦哈哈
软件设计设计模式策略模式
软件设计模式(三)策略模式(StrategyPattern)1.概念2.模式结构3.UML类图4.实现方式C#示例步骤1:定义策略接口步骤2:实现具体策略类步骤3:实现上下文类步骤4:使用策略模式Java示例步骤1:定义策略接口步骤2:实现具体策略类步骤3:实现上下文类步骤4:使用策略模式5.优点6.缺点7.应用场景8.与其他模式的比较小结策略模式变体和实际应用场景1.变体变体1:组合模式与策略模
- 设计模式 -- 策略模式(Strategy Pattern)
xiaoyu❅
设计模式设计模式策略模式
1问题引出1.1鸭子项目有各种鸭子(比如野鸭、北京鸭、水鸭等,鸭子有各种行为,比如叫、飞行等)显示鸭子的信息1.2传统方式其它鸭子,都继承了Duck类,所以fly让所有子类都会飞了,这是不正确的上面说的1的问题,其实是继承带来的问题:对类的局部改动,尤其超类的局部改动,会影响其他部分。会有溢出效应为了改进1问题,我们可以通过覆盖fly方法来解决=>覆盖解决问题又来了,如果我们有一个玩具鸭子ToyD
- 设计模式生产环境实践------策略模式
hungteshun
设计模式策略模式
一、业务背景前端有一棵树形结构的目录,需要实现目录层级的拖拽来变换顺序二、定义接口publicinterfaceITreeStructureStrategy{/***操作树形结构*@paramreqDTO*/voidoperate(TreeStructureOperateReqDTOreqDTO);/***策略实现类-操作类型**@return*/IntegergetType();}三、接口实现定
- EasyExcel表格导出自动列宽设定
SheldonChang
POIexcelpoi
EasyExcel表格导出自动列宽设定publicstaticclassAutoColumnWidthStrategyimplementsCellWriteHandler{@OverridepublicvoidbeforeCellCreate(WriteSheetHolderwriteSheetHolder,WriteTableHolderwriteTableHolder,Rowrow,Headh
- 工厂模式和策略模式的区别
Stringzhua
每日一问策略模式工厂模式
文章目录工厂模式(FactoryPattern)设计意图适用场景结构优点缺点Java实现案例策略模式(StrategyPattern)设计意图适用场景结构优点缺点Java实现案例对比总结工厂模式(FactoryPattern)设计意图工厂模式的主要目的是将对象的创建与使用分离,通过一个工厂类来负责创建实例。这样,当我们需要创建新的对象时,不需要直接使用构造函数,而是通过工厂类来生成对象。这种模式在
- feign调用走不走网关全局拦截_feign在服务间传递header
小葙
场景:用户登陆后,再次访问网页,将用户信息loginToken放在request的header中,首先经过网关,然后到达A服务,然后A服务调用B服务时如何把loginToken传递给B服务1.修改hytrix配置,配置hytrix的strategy为SEMAPHORE。Hystrix提供两种执行隔离策略(ExecutionIsolationStrategy):SEMAPHORE、THREADSEM
- DragonFireFury
lanyue456
Alongtimeago,inapowerfulcountry,therewasakingwholovedmoneyverymuch.Hewantedatreasurewithalotofgemsinthemountainsbuthewasveryafraidofthetyrannosaurusthatguardedthetreasure.Sohecameupwithastrategy,hecal
- springboot策略解决低耦合 函数计算调用问题
烟雨国度
springboot状态模式后端
当然,我理解您现在可能感到有些混乱。让我为您创建一个详细的程序执行流程图,以帮助您更好地理解整个过程。策略选择和计算前端请求处理CalculationStrategyFactory初始化应用启动扫描组件注入策略列表遍历策略列表获取类名转为小写策略实例HTTPPOST解析请求体获取toolname根据toolname查找返回策略实例返回计算结果调用CalculationStrategyFactory
- 解决 Resolved versions for app (26.1.0) and test app (27.1.1) differ的办法
tgcity
在对应的build.gradle文件中添加configurations.all{resolutionStrategy.force'com.android.support:support-annotations:26.1.0'}
- EasyExcel--自定义表头(标题)样式策略
南晓枫
前言:在项目开发中,我们有时候会遇到自定义表头样式的需求。EasyExcel官方文档中关于表头样式的说明有两种(以设置表头颜色为例):方式1:通过使用注解来设置颜色(优点:使用非常方便,缺点:对于复杂表头就无能为力了,例如无法单独设置父表头和子表头的颜色)方式2:通过使用HorizontalCellStyleStrategy策略的方式来设置表头颜色(优点:通过此策略可以对表头设置更多的样式,缺点:
- 【重走编程路】设计模式概述(八) -- 策略模式、模板方法模式
咖啡+=方糖
重走编程路设计模式策略模式模板方法模式
文章目录前言13.策略模式(Strategy)定义解决方案应用场景优缺点14.模板方法模式(TemplateMethod)问题解决方案应用场景优缺点前言行为型模式关注对象之间的交互以及如何分配职责,提供了一种定义对象之间的行为和职责的最佳方式。本章介绍创建型模式中的策略模式和模板方法模式。13.策略模式(Strategy)定义策略模式定义了一系列算法,并将每一种算法封装起来,使它们可以相互替换。策
- 《认知行为疗法入门》回避策略 自弃策略
心理咨询师卜彬
贝克认为,个体为了遮掩其负性核心信念,会发展出一套心理策略,并且通过这套策略使自己看起来(不是别人看来)是正面的形象。这套心理策略被称为补偿策略(CompensatoryStrategy)。对多数个体而言,比较常见的负性核心信念是“无能的”和“不可爱的”两类。常见的补偿策略有以下七个类别:●努力策略;●回避策略;●顺从策略;●归因策略;●警惕策略;●自弃策略;●自恋策略。回避策略是最常见的补偿策略
- 设计模式--策略模式
Liu_Junwei
设计模式设计模式策略模式java
策略模式(StrategyPattern)是一种行为型设计模式,用于定义一系列算法,并将每一个算法封装起来,使它们可以相互替换。策略模式让算法的变化独立于使用算法的客户。主要角色策略(Strategy)接口:定义了一个公共接口,所有具体策略类都需要实现这个接口。具体策略(ConcreteStrategy):实现了策略接口的具体算法。上下文(Context):持有一个策略对象的引用,用于调用策略对象
- 行为模式6.备忘录模式------文本的撤销和保存
臣妾写不来啊
23种设计模式备忘录模式
行为型模式模板方法模式(TemplateMethodPattern)命令模式(CommandPattern)迭代器模式(IteratorPattern)观察者模式(ObserverPattern)中介者模式(MediatorPattern)备忘录模式(MementoPattern)解释器模式(InterpreterPattern)状态模式(StatePattern)策略模式(StrategyPat
- 设计模式-工厂模式和策略模式的区别
workflower
设计方法策略模式设计模式架构课程设计设计规范
工厂模式和策略模式都是设计模式中的重要组件,它们用于解决不同类型的软件设计问题。以下是它们之间的区别:目的不同:工厂模式(FactoryPattern)的主要目的是创建对象。它提供了一种创建对象的接口,使得子类可以决定实例化哪一个类。工厂模式的重点在于如何创建和管理对象。策略模式(StrategyPattern)旨在定义一系列算法,将每个算法封装起来,并使它们可以互换。策略模式使得算法可以在不影响
- Unity游戏中常用的设计模式——策略模式
LittleBridLibrary
Unity3D设计模式unity
策略模式策略模式:它定义了算法家族,分别封装起来,让它们之间可以互相替换,策略模式让算法的变化,不会影响到使用算法的客户。//抽象算法类策略类publicabstractclassStrategy{//算法方法publicabstractvoidAlgorithmInterface();}//具体算法ApublicclassConcreteStrategyA:Strategy{//算法A实现pub
- 【Unity3D与23种设计模式】策略模式(Strategy)
林尧彬
设计模式游戏
GoF中定义:“定义一组算法,并封装每个算法,让它们之间可以彼此交换使用。策略模式让这些算法在客户端使用它们时能更加独立。”游戏开发过程中不同的角色会有不同的属性计算方法初级解决方法便是:ifelse,不够再来几个ifelse高级点儿的就用switchcase配合enum对于小型项目或者快速开发验证用的项目而言,这么做是没问题的但是开发规模或产品化项目时,最好还是选择策略模式在策略模式中,算法中的
- Unity中的策略模式
菜园赤子
设计模式
策略模式主要用于游戏中的数值计算。为不同角色的相同方法提供统一的接口。方便管理。usingUnityEngine;publicclassTest:MonoBehaviour{privatevoidStart(){StrategyContextstrategyContext=newStrategyContext(newConcreteStrategyA());strategyContext.Do()
- 策略模式
蜗牛ICU
前言:因为现在设计模式在网络上已经泛滥,但是还是有好多程序员不能够灵活的运用设计模式,这个是对设计模式简单的介绍,因为网络上比较多类似的文章,所以本人就从网络上抄了一部分,等23种设计模式整理完成之后会根据实际的需求利用设计模式在代码中设计一些开源的插件,请继续关注。原版[菜鸟教程]简介:在策略模式(StrategyPattern)中,一个类的行为或其算法可以在运行时更改。这种类型的设计模式属于行
- 工厂模式和策略模式的核心区别与最佳实践
范范0825
策略模式bash开发语言
工厂模式和策略模式的核心区别与最佳实践在软件设计中,设计模式是解决特定问题的常用方法。工厂模式(FactoryPattern)和策略模式(StrategyPattern)是两种非常重要的设计模式,广泛应用于Java开发中。尽管它们都属于行为设计模式,并且有助于创建灵活、可扩展的代码,但它们的应用场景和核心思想有明显的区别。本文将详细探讨工厂模式和策略模式的核心区别,并结合最佳实践,帮助开发人员在合
- 金融工程--基础策略构建
bw876720687
金融工程金融python
背景1、如何构建良好的策略框架或者多决策模式来保证交易的稳定程度策略SMA策略简单移动平均线(SMA)策略是一种在金融市场中常用的技术分析方法,它通过计算特定时间段内资产价格的平均值来识别市场趋势。SMA策略的核心思想是,当短期SMA上穿长期SMA时,可能是一个买入信号;相反,当短期SMA下穿长期SMA时,则可能是一个卖出信号。classSMAStrategy(bt.Strategy):param
- 23种设计模式之11种行为型模式
如意如意525
设计模式java
11种行为型设计模式行为型设计模式用于处理对象之间的职责、责任和算法的分配。以下是一些常见的行为型设计模式:策略模式(StrategyPattern):定义一系列算法,将它们封装成独立的策略类,使得它们可以互相替换而不影响客户端。观察者模式(ObserverPattern):定义一种一对多的依赖关系,使得当一个对象的状态发生改变时,所有依赖于它的对象都会得到通知和自动更新。模板方法模式(Templ
- 设计模式-策略
ZjyMac
一,策略模式详解概念定义一系列的算法,把他们一个个封装起来,并且使他们可以相互替换,本模式使得算法可独立使用它的客户变化使用场景一个类中定义了多种行为,并且这些行为在这个类的方法中以多个条件语句的形式出现,那么可以使用策略模式避免在类中使用大量的条件语句UMLimage.png代码示例publicinterfaceAbstractStrategy{intcalculatePrice(intkm);
- 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