- 浏览: 280088 次
- 性别:
- 来自: 深圳
文章分类
最新评论
-
tan_1208815066:
传送pdf 的文件 不能正确的 传送
试试用Socket传文件 -
richardri:
结果是0怎么解决?支持mov、mp4、3gp吗?
JAVA獲取視頻文件的播放長度 -
zhujia130:
xiaoyaodandan 写道结果是0.。。。。。你给的路径 ...
JAVA獲取視頻文件的播放長度 -
xiaoyaodandan:
结果是0.。。。。。
JAVA獲取視頻文件的播放長度 -
flowerjacky:
明了
Java事务处理类
前些天在 fuliang 的博客上面看到他写的一个eval算法,我再贴出来,当做收藏,希望fuliang不要介意;
package com.jatula.util; import java.util.ArrayList; import java.util.List; import java.util.Stack; public class Eval { public int eval(String exp){ List<String> list = infixExpToPostExp(exp);//转化成后缀表达式 return doEval(list);//真正求值 } //遇到操作符压栈,遇到表达式从后缀表达式中弹出两个数,计算出结果,压入堆栈 private int doEval(List<String> list) { Stack<String> stack = new Stack<String>(); String element; int n1,n2,result; try{ for(int i = 0; i < list.size();i++){ element = list.get(i); if(isOperator(element)){ n1 = Integer.parseInt(stack.pop()); n2 = Integer.parseInt(stack.pop()); result = doOperate(n1,n2,element); stack.push(new Integer(result).toString()); }else{ stack.push(element); } } return Integer.parseInt(stack.pop()); }catch(RuntimeException e){ throw new IllegalExpressionException(e.getMessage()); } } private int doOperate(int n1, int n2, String operator) { if(operator.equals("+")) return n1 + n2; else if(operator.equals("-")) return n1 - n2; else if(operator.equals("*")) return n1 * n2; else return n1 / n2; } private boolean isOperator(String str){ return str.equals("+") || str.equals("-") || str.equals("*") || str.equals("/"); } private List<String> infixExpToPostExp(String exp){//将中缀表达式转化成为后缀表达式 List<String> postExp = new ArrayList<String>();//存放转化的后缀表达式的链表 StringBuffer numBuffer = new StringBuffer();//用来保存一个数的 Stack<Character> opStack = new Stack<Character>();//操作符栈 char ch,preChar; opStack.push('#'); try{ for(int i = 0; i < exp.length();){ ch = exp.charAt(i); switch(ch){ case '+': case '-': case '*': case '/': preChar = opStack.peek(); // 如果栈里面的操作符优先级比当前的大,则把栈中优先级大的都添加到后缀表达式列表中 while(priority(preChar) >= priority(ch)){ postExp.add(""+preChar); opStack.pop(); preChar = opStack.peek(); } opStack.push(ch); i++; break; case '(': // 左括号直接压栈 opStack.push(ch); i++; break; case ')': // 右括号则直接把栈中左括号前面的弹出,并加入后缀表达式链表中 char c = opStack.pop(); while(c != '('){ postExp.add("" + c); c = opStack.pop(); } i++; break; // #号,代表表达式结束,可以直接把操作符栈中剩余的操作符全部弹出,并加入后缀表达式链表中 case '#': char c1; while(!opStack.isEmpty()){ c1 = opStack.pop(); if(c1 != '#') postExp.add("" + c1); } i++; break; //过滤空白符 case ' ': case '\t': i++; break; // 数字则凑成一个整数,加入后缀表达式链表中 default: if(Character.isDigit(ch)){ while(Character.isDigit(ch)){ numBuffer.append(ch); ch = exp.charAt(++i); } postExp.add(numBuffer.toString()); numBuffer = new StringBuffer(); }else{ throw new IllegalExpressionException("illegal operator"); } } } }catch(RuntimeException e){ throw new IllegalExpressionException(e.getMessage()); } return postExp; } private int priority(char op){//定义优先级 switch(op){ case'+': case'-': return 1; case'*': case'/': return 2; case'(': case'#': return 0; } throw new IllegalExpressionException("Illegal operator"); } public static void main(String[] args) { Eval eval = new Eval(); int result = eval.eval("2+3+55*22+21*2+(3+2)*3+4*3+3*4#"); System.out.println(result); } }
package com.jatula.util; public class IllegalExpressionException extends RuntimeException{ public IllegalExpressionException(){ } public IllegalExpressionException(String info){ super(info); } }
我想说的是,让我想到了Google的搜索可以做计算的用法,虽然这算法以前读书也学过,不过总不能找到一个可以用在实践的地方,终于记下来了;3Q
发表评论
-
反射实现 AOP 动态代理模式(Spring AOP 的实现 原理)
2009-06-09 13:52 1508好长时间没有用过Spring了. 突然拿起书.我都发现自己对A ... -
Resin 3 LOG 设置
2009-06-04 11:51 2097<stdout-log path='${resin.ho ... -
Servlet和ThreadLocal的测试
2009-05-27 15:30 1050作者:中国IT实验室 来 ... -
技巧:利于ThreadLocal模式管理Session
2009-05-27 15:28 1052作者:dxaw 来源:赛迪网 在利用Hibernate ... -
运用Filter,ThreadLocal和Reflection,实现form到bean的填充
2009-05-27 15:27 1329开发者在线 Builder.com.cn 更新时间:2008- ... -
通通透透理解ThreadLocal
2009-05-27 15:24 1047开发者在线 Builder.com.cn ... -
centos 5.2中安装LAMP
2009-05-22 14:52 2342wget至以下目录:/tmp --------------- ... -
基于CentOS的LAMP
2009-05-22 14:50 3398基于CentOS的LAMP 作者:NetSeek ... -
http header详解
2009-01-19 12:19 3179HTTP(HyperTextTransferProtoco ... -
鼠标提示
2008-12-16 17:04 1008<!DOCTYPE html PUBLIC " ... -
SQL备份语句
2008-12-16 16:43 1433--完整备份 Backup Database Northwin ... -
MySQL中修改密码及访问限制设置详解
2008-12-16 16:27 942一、MySQL修改密码方法总结 首先要说明一点的是:一般 ... -
通过GUID生成主键,保证主键全球惟一性
2008-12-16 11:34 1509使用GUID作为数据表主键的好处 使用GUID作为数 ... -
Tomcat对错误页面处理方法的问题
2008-12-15 16:45 2940各位都知道,我们可以在web.xml中定义对错误发生时的提示页 ... -
Hibernate下数据批量处理解决方案
2008-12-12 14:22 876很多人都对Java在批量数据的处理方面是否是其合适的场所持 ... -
任务调度表达式
2008-12-12 14:15 1099字段 允许值 允许的特殊字符 秒0-59 , - * / 分0 ... -
Windows动态库与Linux共享对象比较
2008-12-12 14:13 1498摘要:动态链接库技术 ... -
Java事务处理类
2008-12-10 11:59 1343Mysql5很好的支持了事物处理功能。不过支持这个功能的只有两 ... -
cookie 和session 的区别详解
2008-12-09 13:57 1023这些都是基础知识,不 ... -
jQuery插件---键盘快捷键.
2008-12-01 10:51 2258<!DOCTYPE html PUBLIC " ...
相关推荐
- 多串匹配算法是在一个文本中查找多个特定字符串(子串)的所有出现位置的一种算法。 - 常见的多串匹配算法包括:AC自动机、后缀树、后缀数组、KMP算法等。 - 这类算法广泛应用于文本编辑器、搜索引擎、生物信息...
简单的DH加密算法程序,采用C语言实现,权当学习资料使用; 一共7个函数,加上一个主程序实现; 不用makefile文件编写,直接一个文件编译执行
一卡一密算法分析,简单的一卡一密算法分析
在提供的代码片段中,我们可以看到一个非常简单的对称加密算法的实现。 ##### 2.2.1 第一段代码分析 ```c #include int main() { int a, b, c; printf("请输入明文:\n"); scanf("%d", &a); printf("请输入密钥...
2. **分治算法**:分治策略是将一个大问题分解为两个或更多的相同或相似的子问题,直到最后子问题可以简单的直接求解,原问题的解即子问题的解的合并。典型的分治算法包括快速排序、归并排序和大数乘法等。 3. **...
数学建模30个常用算法(Python)数学建模30个常用算法(Python)数学建模30个常用算法(Python)数学建模30个常用算法(Python)数学建模30个常用算法(Python)数学建模30个常用算法(Python)数学建模30个常用算法...
算法披露的域外经验与启示 算法披露是指将算法的原理、参数和实验结果公开,以提高算法的透明度和可解释性。算法披露有助于促进算法领域的发展和创新,并且可以提高算法的可靠性和信任度。通过算法披露,人们可以更...
算法中的每个粒子代表着一个潜在的解决方案,而粒子群则对应着一个由多个解决方案构成的集合。每个粒子通过不断跟踪个体最优解(pBest)和群体最优解(gBest),在问题的解空间内动态更新自己的位置和速度,进而收敛...
在操作系统中,内存管理是至关重要的一个环节,它涉及到如何有效地分配、使用和回收内存资源。本篇文章将详细探讨三种常见的内存分配算法:首次适应算法(First Fit)、最佳适应算法(Best Fit)以及循环首次适应...
C# 实现一个简单的算法示例
算法图解.pdf,就是个简单的一个pdf,这里有字数要求啊,哎呀哎呀,算法图解算法图解算法图解算法图解算法图解算法图解算法图解算法图解算法图解算法图解算法图解算法图解算法图解算法图解算法图解算法图解算法图解...
扫描算法(SCAN)是一种磁盘调度算法,通过将磁道分成两个部分,一个是从磁盘臂的当前位置到最外圈的磁道,另一个是从磁盘臂的当前位置到最内圈的磁道。该算法的实现思路是,操作系统按照磁道的顺序来执行磁盘读写...
这个银行家算法的实现很简单,只是简单的模拟了操作系统课本上的一个实例
Clock置换算法:为进入内存的页面设置一个访问位,当内存中某页被访问,访问位置一,算法在选择一页淘汰时,只需检查访问位,若为0,则直接换出,若为1,置该访问位为0,检测内存中的下一个页面的访问位。 改进型...
模型算法大全(20+种常用算法模型+代码实现)模型算法大全(20+种常用算法模型+代码实现)模型算法大全(20+种常用算法模型+代码实现)模型算法大全(20+种常用算法模型+代码实现)模型算法大全(20+种常用算法模型+...
这种方式意味着,算法文档中可能会包含一个百度网盘的分享链接,使用该链接可以访问包含算法代码的文件,而不直接在文档中嵌入代码。这种方式的好处是,可以保持算法文档的整洁,避免大量代码段落干扰文档的阅读,...
算法 ,简单 入门 LeetCode网站开放的简单算法题,用于平时检验自己的算法能力,程序设计.
KNN(K-Nearest Neighbor)算法是机器学习算法中最基础、最简单的算法之一,这是一个简单的KNN算法的实现脚本文件,其中有具体的执行代码和提示,
《MATLAB智能优化算法:从写代码到算法思想》一书是一本非常实用的参考书籍,适合对MATLAB智能优化算法感兴趣的读者阅读。通过阅读本书,读者不仅能够深入了解这些算法的原理和实现方法,还能了解它们在各个领域中的...