- 初学者如何用 Python 写第一个爬虫?
陆鳐LuLu
python爬虫开发语言
编写第一个Python爬虫并不难,以下是一个简单的步骤指南,帮助从零开始。1.安装必要的库首先,你需要安装requests和BeautifulSoup这两个库。requests用于发送HTTP请求,BeautifulSoup用于解析HTML内容。pipinstallrequestsbeautifulsoup42.导入库在你的Python脚本中导入所需的库。importrequestsfrombs4
- 用Ruby的Faraday库来进行网络请求抓取数据
q56731523
ruby开发语言后端
在Ruby中,Faraday是一个非常强大的HTTP客户端库,它可以用于发送HTTP请求并处理响应。你可以使用Faraday来抓取网页数据,处理API请求等任务。下面我将向你展示如何使用Faraday库进行网络请求,抓取数据并处理响应。1.安装Faraday如果你还没有安装Faraday,可以通过gem来安装:geminstallfaraday或者如果你使用Bundler,你可以将其添加到你的Ge
- C语言操作MySQL从入门到精通
cmysqlsql数据库
大家好,我是V哥。今天给大家整理的内容是关于使用C语言操作MySQL数据库的详细介绍,从入门到精通,并配有案例代码和注释,帮助小白快速上手。基本操作1.环境准备在开始之前,你需要安装MySQL数据库和MySQLConnector/C开发库。以Ubuntu系统为例,可以使用以下命令进行安装:sudoapt-getupdatesudoapt-getinstallmysql-serverlibmysql
- conda的作用
一只积极向上的小咸鱼
conda
一概览Conda是一个开源的包管理和环境管理工具,主要用于Python及其他编程语言的依赖管理和环境隔离。它的核心作用有以下几点:1.包管理可以安装、更新、卸载Python及其依赖包(类似于pip)。支持多语言(不仅限于Python,还支持C/C++,R,Ruby,Lua等)。依赖自动管理,能解决复杂的库依赖问题,例如:condainstallnumpypandas2.环境管理允许创建多个独立的虚
- 安装docker
chuhx
docker容器运维
有两种方式安装docker,分别是在线安装和离线安装,如果服务器可以连接外网,推荐使用在线安装方式。1、在线安装此处以centos系统为例:yuminstall-yyum-utilsyum-config-manager--add-repohttp://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repoyuminstall-ydocker
- 内网激活JRebel插件(无网络环境)
Cynicism_Smile
后端javaideajrebel
1.官网下载安装包,JRebelandXRebelJRebelandXRebel-IntelliJIDEsPlugin|Marketplace2.以IInstallPluginfromDisk的方式读取3.运行JrebelServer.jar终端输入:java-jarJrebelServer.jar-p8080(默认8080端口)服务会自动打开浏览器至http://localhost:8080/点
- jetson xavier nx conda create --n yourname python=3.6报错
aqzengkuasheng
conda计算机视觉目标检测pytorch边缘计算
Preparingtransaction:doneVerifyingtransaction:doneExecutingtransaction:doneERRORconda.core.link:_execute(699):Anerroroccurredwhileinstallingpackage‘https://mirrors.bfsu.edu.cn/anaconda/pkgs/free::open
- 接口自动化并发执行,多进程
进阶的DW
自动化python运维
一、多进程基础操作1、安装插件pytest-xdist该插件实现进程级别的并发pipinstallpytest-xdist-iSimpleIndex2、使用插件该插件主要使用的是插件提供的pytest执行时的命令行参数,所以我们要在pytest.ini中增加addopts中增加参数*指定并发进程个数-n2#指定两个进程并发-nauto#根据当前电脑cpu自动生成最大进程个数[pytest];-n2
- 第三十一天:Scrapyd的安装及使用
穿梭的编织者
Python爬虫训练营python开发语言
文章目录一、安装scrapyd二、安装setuptools三、部署工程1.创建项目2.启动scrapyd3.部署项目4.配置scrapyd-deploy5.使用scrapyd-deploy四、运行Spider五、查看效果一、安装scrapydpipinstallscrapyd二、安装setuptools为什么要安装这个工具?因为部署的应用需要打包成*.egg才能运行官网下载地址:https://p
- linux centos7 安装nginx
追逐路上的小人物
linuxnginx服务器
1、下载nginx安装包wget-chttp://nginx.org/download/nginx-1.24.0.tar.gz2、安装nginx所需要的依赖包yuminstall-ygcc-c++zlibzlib-developensslopenssl-develpcrepcre-devel3、解压安装包tar-zxvfnginx-1.24.0.tar.gz4、#执行配置脚本--prefix是指定
- c#实现Modbus TCP/IP与RS 485数据交换的实例
A_nanda
c#ModbusRTUModbusTCP/IP
以下是一个具体的C#示例代码,展示如何通过ModbusTCP主站与ModbusRTU(RS-485)从站设备通信,实现协议转换的核心逻辑。代码使用NModbus库简化协议处理。1.环境准备NuGet包安装Install-PackageNModbusInstall-PackageSystem.IO.Ports2.完整代码示例usingSystem;usingSystem.IO.Ports;using
- web项目sso登录配置
互联网搬砖老肖
C#从入门到放弃原力计划webc#
一、依赖引用安装程序包//Winner.Framework.MVC版本[4.0.12]以上install-packageWinner.Framework.MVC//Winner.Platform.MVC版本[4.0.11]以上install-packageWinner.Platform.MVC二、startup.cs代码publicvoidConfigureServices(ISerivceCol
- electron踩坑之安装报错 Electron uninstall
王——小喵
electronjavascript前端
在启动一个electron项目前,pnpminstall了使用到的库,但在启动时,报错Electronuninstall尝试忽略的包内的脚步预下载设置,需要修改npm或者yarn的设置yarnconfigsetignore-scriptsfalse删除node_modules后运行pnpmstoreprune清除缓存后重新安装,仍然报错后来执行node.\node_modules\electron
- 信息安全之构建FTP服务器证书
云纳星辰怀自在
信息安全概念sslhttpsFTP服务器CA证书
以下是完整的文章,包含所有步骤和最后一节的参考文章部分:在Ubuntu中安装和配置FTPS服务器的详细指南1.安装vsftpd首先,确保你的系统是最新的,然后安装vsftpd:sudoaptupdatesudoaptinstallvsftpd•解释:vsftpd是一个轻量级且安全的FTP服务器软件,适用于大多数Linux发行版。2.检查并安装openssl检查openssl是否已安装:whicho
- pycharm ssh 远程连接docker 容器 进行debug调试代码
Panesle
pycharmsshdocker
pycharmssh远程连接docker容器进行debug调试代码1.用镜像启动好一个容器2.安装ssh工具aptupdateapt-getinstall-yopenssh-server3.配置ssh的config文件vim/etc/ssh/sshd_config配置修改好(端口、登陆权限):Port3210PermitRootLoginyesPasswordAuthenticationyes4.
- 预置第三方apk到MTK项目相关问题总结
System_sleep
androidMTK三方apk预置
预置第三方apk到MTK项目相关问题总结标签:MTK预置apk目前5.0之后项目预置方式通用步骤为:建立apk文件夹;置目标apk到该文件夹下;解压缩apk查看是否包含lib/文件夹(apk项目是否包含lib库文件);在该文件夹下编写Android.mk脚本;理论上apk文件夹可以建立在项目内任意目录,编译系统会自动搜索并根据其内Android.mk(编译脚本)来进行编译。编译系统采用的是递归搜索
- win11编译pytorch cuda128版本流程
System_sleep
pytorch人工智能python编译windowscuda
Geforce50xx系显卡最低支持cuda128,torchcu128release版本目前还没有释放,所以自己基于2.6.0源码自己编译wheel包。1.前置条件1.使用visualstudioinstaller安装visualstudio2022,工作负荷选择【使用c++的桌面开发】,安装完成后将“VC\Tools\MSVC\\bin\Hostx64\x64”对应的路径加入环境变量;2.访问
- React:Axios、Fetch-Jsonp获取API接口数据
今天也很棒棒~
Reactreact.jsjavascriptjson
不同模块可登录npm,搜索对应方法有官方文档https://www.npmjs.com/Axios步骤:{/*axios1.npminstallaxios--save安装axios模块2.importaxiosfrom'axios';3.varapi='http://www.phonegap100.com/appapi.php?a=getPortalList&catid=20';//接口后台允许了
- 【python】软件更新:用conda或Poetry
无水先生
AI原理和python实现python指南和应用人工智能综合pythonconda开发语言
一、说明在实现anancoda的软件更新问题,需要明确几个问题:1)是python包吗?2)是C++包吗?更新的方法有别。python包可以pip访问。C++包必须是conda访问。二、更新C++包的循环依赖问题如果在Windows10上的Ananconda3.7上安装和更新软件包。运行代码时:condaupdate--all或者condainstallpandas收到以下错误:RemoveErr
- 使用OpenCV和Python将图像读取为RGB
UixnContext
opencvpython人工智能OpenCV
在计算机视觉和图像处理中,OpenCV是一个广泛使用的开源库,提供了许多功能强大的图像处理工具。其中一个常见的任务是将图像读取为RGB格式,以便进一步处理和分析。在本文中,我将向您展示如何使用OpenCV和Python来实现这个任务。首先,确保您已经安装了OpenCV库。您可以使用以下命令在Python中安装OpenCV:pipinstallopencv-python一旦安装完成,我们可以开始写代
- vscode配置python调试_vscode配置python调试(debug)
weixin_39747049
vscode作为宇宙级编辑器,已经越来越多人开始使用它。而它的扩展也琳琅满目,在这里我们介绍下vscode下如何进行python开发和调试。首先,我们需要安装python扩展,打开编辑器,输入ctrl+p,然后输入命令extinstall打开扩展搜索。在扩展里面搜素python扩展,然后安装。创建一个文件夹,然后使用vscode打开这个文件夹创建一个文件,然后命名为index.py。配置调试文件,
- Python环境迁移到另一台电脑的Anaconda环境下
Calvad0s
Pythonpythonlinux开发语言Anacondaconda
目录一、使用命令导出当前环境的依赖包二、将requirements.txt文件复制到另一台电脑上三、在Anaconda环境中使用命令进行导入一、使用命令导出当前环境的依赖包pipfreeze>requirements.txt二、将requirements.txt文件复制到另一台电脑上三、在Anaconda环境中使用命令进行导入pipinstall-rrequirements.txt
- Installing Anaconda on Raspberry Pi 4 with Ubuntu 20.04
pertain99
UbuntuLinux
RaspberryPi4runson32-bit.Usethe32-bitversionsandyoushouldbeokay!I’verecentlyinstalledminicondaonmyRaspberryPi4.Ididitusingthefollowingcommands:#Updatelinuxsudoaptupdate-y#Installpython3sudoaptinstall-
- 使用conda-pack向内网服务器复制重现一个项目虚拟环境
J_caicaicai
LinuxPython服务器python
thisisthecase,目前有两台服务器,相同操作系统,一台可以连外网,一台不可以。所以可以借助能连外网的机器,去先将跑python程序的环境准备好,然后使用condapack复制到无法连外网的机器上。机器A:连外网机器机器B:内网机器第一步:现在机器A上像往常一样,创建项目的虚拟环境example_env,condainstall各种有的没有第二步:在机器A上切换虚拟环境到base上,在ba
- ubuntu ffmpeg的学习历程 -- chapter 1
ErisX
ubuntuffmpeg开发ubuntuffmpeg学习
学习目标:在ubuntu18.04系统上面使用ffmpeg完成视频的采集与H.264硬件编码,抽帧。学习历程:一、ffmpeg安装(非源码安装)直接使用指令进行安装,考虑系统与版本的匹配性,暂不用源码安装,直接apt-get安装编译好的版本。//安装指令sudoapt-getinstallffmpeg//安装好后查询版本信息sudoffmpeg-version//查询编码器sudoffmpeg-e
- 第五章 nfs服务器
Chen_l916
phplinux开发语言
NFS(NetworkFileSystem,网络文件系统)是FreeBSD支持的文件系统中的一种,它允许网络中的计算机(不同的计算机、不同的操作系统)之间通过TCP/IP网络共享资源,主要在unix系列操作系统上使用。在NFS的应用中,本地NFS的客户端应用可以透明地读写位于远端NFS服务器上的文件,就像访问本地文件一样。nfs配置[root@localhost~]#yuminstallrpcbi
- 04单细胞分析2025-Ubuntu22.04安装jupyter notebook 和 scanpy环境
lsxybe
jupyterpythonscanpyubuntulinux
创建新的环境scanpy312condacreate-nscanpy312python=3.12查看有几个环境condainfo-econdaactivatescanpy312安装jupyternotebookcondainstall-canacondanotebookjupyternotebook--no-browser安装scanpy$condainstall-cconda-forgescan
- chatglm3如何进行微调
learner_ctr
人工智能chatglm3llm
一、需要的环境内存:因为在loadmodel时,是先放在内存里面,所以内存不能小,最好在30GB左右显存:如果用half()精度来loadmodel的话(int4是不支持微调的),显存在16GB就可以,比如可以用kaggle的t4gpu,这款性能相当于2070系列,但是显存翻倍python:3.10即可需要安装的包和版本:!pipinstallmodelscope-ihttps://pypi.tu
- python库下载——清华源
爱吃鱼的猫℡
python
pipinstalltensorflow-ihttps://pypi.tuna.tsinghua.edu.cn/simple/这段代码是用来通过pip安装TensorFlow库的命令,其中包含了以下内容:pipinstalltensorflow:这部分命令告诉pip工具去安装名为TensorFlow的Python库。-ihttps://pypi.tuna.tsinghua.edu.cn/simpl
- python之爬虫入门实例
我不是少爷.
Python爬虫python爬虫开发语言
链家二手房数据抓取与Excel存储目录开发环境准备爬虫流程分析核心代码实现关键命令详解进阶优化方案注意事项与扩展一、开发环境准备1.1必要组件安装#安装核心库pipinstallrequestsbeautifulsoup4openpyxlpandas#各库作用说明:-requests:网络请求库(版本≥2.25.1)-beautifulsoup4:HTML解析库(版本≥4.11.2)-openpy
- 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