面向对象第一话,大战java正则表达式
本周我们迎来第一项任务,java面向对象之实现对一串字符的匹配以及构造出计算的多项式,最终得出计算的结果。简而言之,可以用以下的要求来看题目:
- 输入的多项式字符串中不得出现非法字符
 - 多项式的输入型式,{多项式 1}+{多项 式 2}-…… +{多项式 n},多项式内部格式为{(c1,n1),(c2,n2),…,(cm,nm)}
 - 其中多项式的输入个数不得超过20个,同时多项式的内部数据的对数不会超过50对
 - 输入中的所有空格应该被过滤掉
 - 在本次编程过中, 对 于数(c,n),c为系数, 有-10^6<c<10^6(即 c前面可以 有‘ -’) , n为幂, 有 0<=n<10^6,即 c最大为 6位十进制整数, 位十进制整数, n最大为 6位十进 制整数。所有均可能出现前导 制整数。所有均可能出现前导 0,但 c和 n除去符号位之外的长度分别不超过 6和 6。
 - 对于所有的不合法的输入,程序要给出响应,即输出为“ERROR”
 
那我们社会人应该怎么解决这道题目呢?
如果按照面向流程的思路设计,我们以c语言为例,首先是判断输入是否合法,采用的方法是对输入进行输入流判断,然后就是一路遍历,取出合法的多项式,然后构成多项式,最后进行计算,而作为初入面向对象的小白来说,第一次作业就用面向对象来写,着实有些困难,所以在下还是用一个C语言的形式来实现这个作业了,那么我是具体如何实现的呢?
首先是正则表达式:对于转换可以大家可以自行搜索,主要讲一下正则表达式的匹配的吧,对于该问题,我是这样考虑的,从整体的多项式的结构来看,我们分析其中的字符特点,有以下几个特点:
- 对于输入字符串的第一个和最后一个字符,只能是‘{’和‘}‘,当然这里是过滤了开头的字符,因为那本身并没有太大意义
 - 统计输入字符串,对于合法的输入,‘{’的个数一定等于‘}’的个数,一定等于“\\{(\\([+-]?[0-9]{1,6},(([+]?[0-9]{1,6})|([-]?[0]{1,6}))\\),){0,49}\\([+-]?[0-9]{1,6},(([+]?[0-9]{1,6})|([-]?[0]{1,6}))\\)\\}”的个数,且一定比”\\}[+-]\\{“多一个,所以我们采用统计这几类正则表达式的个数来判断输入字符串是否合法
 - 在统计的过程中对输入的个数进行判断,
 - 最后我们提取出每一个多项式,并在多项式中提取出数字
 - 根据之前我们在分段时候采用的”\\}[+-]\\{”,将计算符号记录下来,最后进行计算,
 
关于正则匹配的代码
public static void find(String All_2, String str_num) {
        Pattern p_2 = Pattern.compile(str_num);
        Matcher m_2 = p_2.matcher(All_2);
        while(m_2.find() && result4==1) {
            formula(big, m_2.group(), no_5);
            big++;
        }
    }
这里ALL_2,表示输入的字符串,str_num表示多项式的正则表达式,find()函数就是找出符合条件的多项式,在find()内部调用formula的作用是分析多项式,取出数字,为了计算多项式的个数我们采用了m.find()方法,而不是matches(),是正则表达式的完全匹配,而find()是包含匹配,所以能过找到多个不同的符合条件的式子,其实对于这一过程使用split也可以达到同样的效果。之后的计算以及输出过程就不做过多的叙述了。
面向对象第一话,大战java正则表达式的更多相关文章
- java正则表达式
		
java正则表达式 1.Java正则表达式的语法与示例: http://baike.xsoftlab.net/view/207.html 2.Java 正则表达式: http://www.runo ...
 - Java正则表达式入门——转自RUNOOB.COM
		
Java 正则表达式 正则表达式定义了字符串的模式. 正则表达式可以用来搜索.编辑或处理文本. 正则表达式并不仅限于某一种语言,但是在每种语言中有细微的差别. Java正则表达式和Perl的是最为相似 ...
 - Java 正则表达式详解
		
Java 提供了功能强大的正则表达式API,在java.util.regex 包下.本教程介绍如何使用正则表达式API. 正则表达式 一个正则表达式是一个用于文本搜索的文本模式.换句话说,在文本中搜索 ...
 - 【转】详解Java正则表达式语法
		
(转自: http://www.jb51.net/article/76354.htm) 这篇文章主要介绍了Java正则表达式语法,包括常用正则表达式.匹配验证-验证Email是否正确以及字符串中查询字 ...
 - java正则表达式【大全】
		
[正则表达式]文本框输入内容控制整数或者小数:^[0-9]+\.{0,1}[0-9]{0,2}$只能输入数字:"^[0-9]*$".只能输入n位的数字:"^\d{n}$& ...
 - JAVA正则表达式:Pattern类与Matcher类详解(转)
		
java.util.regex是一个用正则表达式所订制的模式来对字符串进行匹配工作的类库包.它包括两个类:Pattern和Matcher Pattern 一个Pattern是一个正则表达式经编译后的表 ...
 - JAVA正则表达式:Pattern类与Matcher类详解
		
java.util.regex是一个用正则表达式所订制的模式来对字符串进行匹配工作的类库包.它包括两个类:Pattern和Matcher Pattern 一个Pattern是一个正则表达式经编译后的表 ...
 - Java 正则表达式[转载]
		
PS:转载自CSDN博客看上去很美 众所周知,在程序开发中,难免会遇到需要匹配.查找.替换.判断字符串的情况发生,而这些情况有时又比较复杂,如果用纯编码方式解决,往往会浪费程序员的时间及精力.因此,学 ...
 - Java正则表达式的应用
		
在很多种情况下,我们都必须对字符串进行匹配,以便判断字符串的格式是否符合要求,对字符串中的内容进行提取.比如,我要从一段话aabdfe中,判断这段话是否有包含ab这个词,那么如果用if-else来判断 ...
 
随机推荐
- Dividing the Path POJ - 2373  dp
			
题意:你有无数个长度可变的区间d 满足 2a<=d<=2b且为偶数. 现在要你用这些区间填满一条长为L(L<1e6且保证是偶数)的长线段. 满足以下要求: 1.可变区间之间不能有 ...
 - Pymongo NotMasterError while fetching count of the collection as per query from MongoDB in DRF
			
django rest framework - Pymongo NotMasterError while fetching count of the collection as per query f ...
 - SET NAMES
			
High Performance MySQL, Third Editionby Baron Schwartz, Peter Zaitsev, and Vadim Tkachenko Settings ...
 - 洛谷P3209平面图判定  [HNOI2010] 2-sat
			
正解:2-sat(并茶几/强连通分量 解题报告: 传送门w 难受死了,连WA5次,正确率又-=INF了QAQ 然后先说下这题怎么做再来吐槽自己QAQ 首先这题其实和NOIp2010的关押罪犯挺像的,然 ...
 - python 全局变量引用与修改
			
一.引用 使用到的全局变量只是作为引用,不在函数中修改它的值的话,不需要加global关键字.如: #! /usr/bin/python a = 1 b = [2, 3] def func(): if ...
 - javaScript高级教程(八)-----正则表达式温故知新
			
1.RegExp对象:五个属性二个方法 五个属性:global, ignoreCase,multiline,lastIndex,source 二个方法: exec()--模式匹配 test()--检测 ...
 - ifame_自适应高度
			
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
 - Linux文件目录介绍及文件颜色区别
			
文件颜色代表含义: 蓝色表示目录: 绿色表示可执行文件: 红色表示压缩文件: 浅蓝色表示链接文件: 白色表示其他文件: 黄色是设备文件,包括block, char, fifo. 常见目录解释 Linu ...
 - windows server r2 搭建 ftp服务器
			
1:安装ftp服务器 开始>管理工具>服务器管理器>打开服务器管理器,找到添加角色,然后点击,弹出添加角色对话框,选择下一步>选择Web服务器(IIS),然后选择FTP服务,直 ...
 - [vue]vue条件渲染v-if(template)和自定义指令directives
			
条件渲染: v-if/template <div id="app"> <h1>v-show: display: none</h1> <di ...