一、什么是宏函数?通过宏定义的函数是宏函数。如下,编译器在预处理阶段会将Add(x,y)替换为((x)*(y))#defineAdd(x,y)((x)*(y))#defineAdd(x,y)((x)*(y))intmain(){inta=10;intb=20;intd=10;intc=Add(a+d,b)*2;cout<
什么是函数?编写Python函数的步骤?
老男孩IT教育
python开发语言
Python函数是指组织好的、可重复使用的、用来实现单一或相关联功能的代码段。Python函数包含系统中自带的一些函数、第三方函数、以及用户自定义的函数,那么Python如何编写函数?我们通过这篇文章来介绍一下。函数是一组可重复使用的代码块,用于执行特定的任务。它们可以接受输入,执行所需的处理,然后返回输出。编写Python函数的步骤:1、定义函数使用def关键字定义函数,后跟函数名称和圆括号。d
Rust 函数
lly202406
开发语言
Rust函数Rust是一种系统编程语言,以其安全性、速度和并发性而闻名。在Rust中,函数是一等公民,是组织代码和实现功能的基本单位。本文将深入探讨Rust中的函数,包括其定义、特性、参数、返回值以及高级用法。函数定义在Rust中,函数使用fn关键字定义。函数可以有参数和返回值。下面是一个简单的函数定义示例:fngreet(name:&str)->String{format!("Hello,{}!
Python 列表 sort()函数使用理解
Echo_3wdiankang
python爬虫开发语言
目录前言1、升序降序2、sort()和sorted()的区别3、切片排序4、指定排序规则4.1、按字符串长度排序4.2、按第二个字符排序4.3、查找第n大的元素5、其他类型排序总结前言在Python编程的广阔领域中,列表(List)是一种非常基础且强大的数据结构。它允许我们存储多个元素,并按需进行访问、修改和操作。在这些操作中,对列表进行排序是一个常见的需求,而Python的sort()函数正是为
c++的运算符重载的局限性
zzt_is_me
c++开发语言
运算符重载的局限性1、无法重载的运算符.成员访问运算符::作用域运算符sizeof长度运算符?:条件运算符#预处理符号2、只能重载为成员函数的运算符在C++中,有几个函数只能被重载为成员函数,它们分别是:赋值运算符重载=,也叫赋值函数,要进行深拷贝时就需要重载。索引运算符重载[],可以把对象伪装成数组使用。函数调用运算符重载(),可以把对象伪装成函数使用。成员访问运算符重载->,可以把对象伪装成指
c++的this指针与常函数
zzt_is_me
c++开发语言
this指针与常函数成员函数是如何区别调用它的对象?#includeusingnamespacestd;classTest{ constintnum;public: Test(intnum):num(num){} voidshow(void) { cout,所以可以区别出每个对象的成员变量。5、由于成员函数参数列表中都隐藏着this指针,所以普通的成员函数无法作为回调函数使用。#in
Python 函数使用指南:定义、参数设置与变量作用域详解
敲代码不忘补水
Python编码python开发语言
Python函数使用指南:定义、参数设置与变量作用域详解文章目录Python函数使用指南:定义、参数设置与变量作用域详解一函数1未定义函数的常规操作2定义函数3不含输入参数的函数4拿出函数处理的结果(有返回参数)5参数设置二全局和局部变量1私有变量2公有变量3变量值修改三完整文件示例四源码地址本文详细介绍了Python中函数的定义与使用,包括如何通过定义函数减少重复操作、处理输入参数、设置默认值及
千字长文讲解python闭包
不负长风
#python基础编程python开发语言
1.闭包的作用a.闭包可以保存函数内的变量,不会随着函数调用完而销毁2.闭包的定义a.在函数嵌套的前提下,内部函数使用了外部函数的变量,并且外部函数返回了内部函数,我们把这个使用外部函数变量的内部函数称为闭包3.闭包示例#函数嵌套defouter_func(num1):definner_func(num2):#内部函数使用了外部函数的变量或外部函数的参数num=num1+num2print(f'n
第四十九章 Caché 函数大全 $PIECE 函数
Cache技术分享
第四十九章Caché函数大全$PIECE函数使用定界符返回或替换子字符串。大纲$PIECE(string,delimiter,from,to)$P(string,delimiter,from,to)SET$PIECE(string,delimiter,from,to)=valueSET$P(string,delimiter,from,to)=value参数string标识分隔的子字符串的目标字符串
mysql之连接符函数使用sql顺序以及键约束介绍
calmtho
数据库mysql
文章目录单表查询1.格式2.关键字连接符操作符等3.分组函数/聚合函数/多行处理函数2.连接查询3.进阶类关键字1.union合并查询结果集2.limit分页时间表的键存储引擎mysql执行脚本指令案例sql脚本单表查询1.格式select...from...where...groupby...having...orderby...执行顺序:1.from2.where3.groupby4.havi
HBase 源码阅读(一)
Such Devotion
hbase数据库大数据
1.HMastermain方法在上文中MacosM1IDEA本地调试HBase2.2.2,我们使用HMaster的主函数使用"start"作为入参,启动了HMaster进程这里我们再深入了解下HMaster的运行机理publicstaticvoidmain(String[]args){LOG.info("STARTINGservice"+HMaster.class.getSimpleName())
PostgreSQL 中的 `generate_series` 函数使用
盖盖衍上_染染熊
中间件postgresql
1.概述在PostgreSQL中,generate_series是一个非常实用的内置函数,它能够根据给定的起始值和结束值生成一系列连续的数字。这一功能对于需要生成大量连续数据或进行批量操作的场景非常有用。本文将详细介绍generate_series函数的基本用法,并通过一些简单的示例帮助你更好地理解和应用这一函数。2.基本用法generate_series函数的基本语法如下:generate_se
python之eval函数使用详解
吴少凡
python开发语言自动化
eval()是Python内置的一个函数,它可以将字符串最外侧的引号去掉,并且按照python语句方式执行去掉引号后的代码(去掉引号后,代码可能还是字符串,可能是数字,可能是列表,可能是执行函数的代码块等等),---用于执行字符串表达式。1.eval()函数的语法eval()函数的语法如下:eval(expression,globals=None,locals=None)参数:expression
Python——json的封装与解析
hjhkkkl
pythonjson
SON(JavaScriptObjectNotation)是一种轻量级的数据交换格式,易于人阅读和编写。JSON函数使用JSON函数需要导入json库:importjson。函数描述json.dumps将Python对象编码成JSON字符串json.loads将已编码的JSON字符串解码为Python对象json.dumpsjson.dumps用于将Python对象编码成JSON字符串。语法jso
python开方(开根号)的三种写法
weixin_44226291
python算法开发语言
1.使用幂运算符号用0.5次幂表示开根。a=9**0.5#3.02.使用sqrt函数使用sqrt函数需导入math库,该函数的直接作用就是开根,无需加其他参数。importmatha=math.sqrt(9)#3.0若计算的是复数平方根,即参数值小于0时,需使用库cmath的sqrt,如下:importcmatha=cmath.sqrt(-10)#3.1622776601683795j3.使用内置
pytorch torch.sigmoid、torch.nn.Sigmoid和torch.nn.functional.sigmoid的区别
puspos
torch.sigmoid:函数torch.sigmoid(input_tensor,out=None)->Tensortorch.nn.Sigmoid:class应该看作网络的一层,而不是简单的函数使用。模型的初始化方法中使用,需要在_init__中定义,然后在使用classModel(torch.nn.Module):def__init__(self):super(Model,self
Python 定义和调用函数
Itmastergo
python开发语言
在Python编程中,函数是组织和重用代码的一种重要方式。函数可以提高代码的可读性和维护性,并且可以避免重复代码。1.定义函数在Python中,函数使用def关键字定义。一个简单的函数定义包括函数名、参数列表和函数体。以下是一个基本的函数定义示例:defgreet(name):"""打印问候语。参数:name(str):要问候的人名。"""print(f"Hello,{name}!")在这个例子中
mysql字符串函数使用方式
m0_46429209
mysql学习mysql
1.concat()可以将多列内容连接在一起或给某列数据追加内容eg:selectconcat(column1,’-’,column2)AScolfromtable_name将column1和column2的内容用'-'连接2.IFNULL();指定遇到NULL时,改为显示其他内容eg:selectIFNULL(book_name,'')frombooks;3.lower()和upper()low
函数是什么及怎么定义、怎么使用
code汪
C语言
原博客地址:http://www.codertown.cn/blog/?p=141函数相关,比如编译之后是什么,函数名的表,定义函数,涉及到return、形参、实参等等,什么是参数一、函数使用方法什么是函数,可自行百度百科可得到原始的定义,其实就是一个数函另一个数,简称函数。简单的理解就是一个数通过一个算式得到另外的数。比如y=x+4;x和y的关系式不变,给一个x就能得到一个y。先来看下编程中的函
【随手记】excel中的text函数使用
zcongfly
随手记excelui
参考链接:https://support.microsoft.com/zh-cn/office/text-%E5%87%BD%E6%95%B0-20d5ac4d-7b94-49fd-bb38-93d29371225c我自己的一个需求是,将我在excel中格式为0.13422319(0.29373067)0.25659165(0.44515750)+0.31426764(0.46226351)-0.
unity3d引擎缓存优化技术_unity3d优化总结篇
weixin_39732991
unity3d引擎缓存优化技术
转自http://www.unitymanual.com/thread-21597-1-1.html此总结由自己经验及网上收集整理优化内容包括:1.代码方面;2.函数使用方面;3.ngui注意方面;4.数学运算方面;5.内存方面;6.垃圾回收方面等等...本着相互交流共同进步的原则好了,总结如下:1.尽量避免每帧处理,可以每隔几帧处理一次比如:[C#]纯文本查看复制代码functionUpdate
cv2 python_【cv2模块 python3】
正定幢
cv2python
Pythonopencv模块cv2安装和部分函数使用前几天做了一下验证码识别,在这里分享一下用到的opencv模块cv2部分函数的使用方法,也是给自己加深一下记忆。一、cv2模块安装在这里提醒一下这里有坑欧你如果直接用pipinstallcv2会报错欧往下看解决办法可以通过pipinstallopencv-python来进行安装如果pip不能安装还可以通过https://pypi.tuna.tsi
python基础语法 - 函数
江南小作坊
Python学习笔记python其他
函数What(是什么)Why(为什么)How(怎么用)定义函数调用函数使用位置调用使用关键字参数调用参数设置默认值可变参数基于元组基于字典作用域函数类型过滤函数filter()映射函数map()lambda()函数What(是什么)首先,函数是什么?函数是带名字的代码块,用于完成具体的工作。函数是将代码裹起来的一种封装。函数具有函数名、参数、返回值。不同地方的函数:在模块之内,类之外的函数,称为函
Baumer工业相机堡盟工业相机如何通过NEOAPI SDK设置相机本身的数据保存(CustomData)功能(python)
格林威
工业相机数码相机python计算机视觉视觉检测开发语言
Baumer工业相机堡盟工业相机如何通过BGAPISDK设置相机本身的数据保存(CustomData)功能(python)Baumer工业相机Baumer工业相机的数据保存(CustomData)功能的技术背景CameraExplorer如何使用数据保存(CustomData)功能在NEOAPISDK里通过函数使用数据保存(CustomData)功能功能Baumer工业相机通过NEOAPISDK使
软件设计之MySQL(9)
柳叶寒
软件设计之MySQLmysql数据库
软件设计之MySQL(9)此篇应在JavaSE之后进行学习:路线图推荐:【Java学习路线-极速版】【Java架构师技术图谱】Navicat可以在软件管家下载``使用navicat连接mysql数据库创建数据库、表、转储sql文件,导入sql数据MySQL数据库入门到大牛,mysql安装到优化,百科全书级,全网天花板资料可以去尚硅谷官网免费领取学习内容:触发器窗口函数使用(MySQL新特性)公用表
独立开发者系列(45)——PHP的时间处理详解
大梁来了
转型独立开发者php
编程里面,时间函数使用相对比较复杂。变化种类比较多,使用场景也比较丰富。(1)基础用法在PHP中,时间戳是一个整数,表示自Unix纪元(1970年1月1日00:00:00GMT)以来的秒数。使用time()获取当前时间戳如果需要对时间戳进行格式化使用date(“Y-m-dH:i:s”)获取当前的时间,按照我们正常的格式输出的时间格式。如果需要将我们看到的时间2020-10-12020-11-151
C语言文件相关函数
Beginner_bml
开发语言c语言
目录一、引言二、文件函数概述1.文件类型指针2.常用文件函数三、文件函数使用详解1.打开文件2.关闭文件3.写入文件4.读取文件5.二进制文件操作四、实战应用五、总结本文将详细介绍C语言中文件函数的基本概念、常用函数及其使用方法,并通过实例讲解如何在实际项目中应用文件函数进行数据的读写操作。掌握这些知识,将有助于提高C语言编程能力,为后续的项目开发奠定基础。一、引言在C语言编程中,文件操作是不可或
MySQL空间函数ST_Distance_Sphere()的使用
niceLiuSir
mysql
MySQL提供了一系列的空间函数,其中ST_Distance_Sphere()函数可以计算两个经纬度坐标之间的距离,返回单位为米的浮点数。这个函数使用的是球形大地模型,因此对于较短的距离,计算结果的精度比较高。下面是一个使用ST_Distance_Sphere()函数计算两个经纬度之间距离的示例:SELECTST_Distance_Sphere(POINT(-122.4194155,37.7749
使用C++编写程序,提示并输入一个字符串,统计其中的英文字符,数字,空格以及其他字符的数量。
睡觉然后上课
C++c++开发语言qt
由于c++兼容c语言的程序,所以子函数使用了c语言的内容#include#includeusingnamespacestd;voidCount(constcharstr[]){intletter=0,num=0,space=0,etc=0;while(*str!='\0'){if((*str>='a'&&*str='A'&&*str='0'&&*str<='9'){num++;}elseif(*s
golang内置函数的使用
JinChanle
个人开发golang
前言:在使用多个goroutine中遇见panic问题,写了较全面的内置函数使用目录funcappend(slice[]Type,elems...Type)[]Typefunccap(vType)intfuncclose(cchan<-Type)funccomplex(r,iFloatType)ComplexTypefunccopy(dst,src[]Type)intfuncdelete(mmap
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