时间:2021-05-26
工作中遇到一个问题,两个字符串匹配,要求:每个字符串中最多含有一个*,?可以无限多个
*代表一个任意长度的字符串,而?则代表一个字符
要求可以提示出两个冲突
复制代码 代码如下:<input type="text" id="str1"><br>
<input type="text" id="str2"><br>
<input type="button" onclick="checkMarchX()" value="CHECK">
用JavaScript实现代码如下:
function checkMarchX(){ var str1 = document.getElementById('str1').value; var str2 = document.getElementById('str2').value; var str1XPosition = str1.indexOf('*'); var str2XPosition = str2.indexOf('*'); if(str1XPosition!=-1 && str2XPosition!=-1)//两者都含有* { var position = str1XPosition>str2XPosition?str2XPosition:str1XPosition;//success if(position!=0) { var patbeforeStr1 = str1.substring(0,position); var patbeforeStr2 = str2.substring(0,position); if(checkMarchQ(patbeforeStr1,patbeforeStr2)) { //alert(str1+'与'+str2+"前半部分冲突"); //然后对应后半部分进行测试 var str1XBackPosition = str1.length-str1XPosition-1; var str2XBackPosition = str2.length-str2XPosition-1; var backposition = str1XBackPosition>str2XBackPosition?str2XBackPosition:str1XBackPosition; if (backposition==0) { alert(str1+'与'+str2+"冲突"); } else { var patbackStr1 = str1.substring(str1.length-backposition,str1.length); var patbackStr2 = str2.substring(str2.length-backposition,str2.length); if(checkMarchQ(patbackStr1,patbackStr2)) { alert(str1+'与'+str2+"冲突"); } } } } else { //alert(str1+'与'+str2+"前半部分冲突"); var str1XBackPosition = str1.length-str1XPosition-1; var str2XBackPosition = str2.length-str2XPosition-1; var backposition = str1XBackPosition>str2XBackPosition?str2XBackPosition:str1XBackPosition; if (backposition==0) { alert(str1+'与'+str2+"冲突"); } else { var patbackStr1 = str1.substring(str1.length-backposition,str1.length); var patbackStr2 = str2.substring(str2.length-backposition,str2.length); if(checkMarchQ(patbackStr1,patbackStr2)) { alert(str1+'与'+str2+"冲突"); } } } } else if((str1XPosition==-1 && str2XPosition!=-1)||(str1XPosition!=-1 && str2XPosition==-1))//有且只有一个字符串含有* { var strX = str1XPosition==-1?str2:str1;//含有*的字符串 var strNoX = str1XPosition==-1?str1:str2;//不含*的字符串 if (strX.length-1<strNoX.length) { var position = strX.indexOf('*'); if(position==0) { //alert(str1+'与'+str2+"前半部分冲突"); var backposition = strX.length-position-1; if (backposition==0) { alert(str1+'与'+str2+"冲突"); } else { var patbackStr1 = str1.substring(str1.length-backposition,str1.length); var patbackStr2 = str2.substring(str2.length-backposition,str2.length); if(checkMarchQ(patbackStr1,patbackStr2)) { alert(str1+'与'+str2+"冲突"); } } } else { var patbeforeStr1 = str1.substring(0,position); var patbeforeStr2 = str2.substring(0,position); if(checkMarchQ(patbeforeStr1,patbeforeStr2)) { //alert(str1+'与'+str2+"前半部分冲突"); var backposition = strX.length-position-1; if (backposition==0) { alert(str1+'与'+str2+"冲突"); } else { var patbackStr1 = str1.substring(str1.length-backposition,str1.length); var patbackStr2 = str2.substring(str2.length-backposition,str2.length); if(checkMarchQ(patbackStr1,patbackStr2)) { alert(str1+'与'+str2+"冲突"); } } } } } } else { if(checkMarchQ(str1,str2)) { alert(str1+'与'+str2+"冲突"); } }}function checkMarchQ(str1,str2){ var flagque = false; if(str1.length==str2.length) { //长度相同才有可能冲突 for (var i=0 ;i<str1.length ;i++ ) { if(str1.substr(i,1)!='?' && str2.substr(i,1)!='?') { if(str1.substr(i,1)!=str2.substr(i,1)) { flagque = false;//表示不冲突 break; } else { flagque = true;//表示冲突 } } } } return flagque;}其中*最起码为一个字符,以上程序并没有对输入的合法性进行验证
查看更多JavaScript的语法,大家可以关注:《JavaScript 参考教程》、《JavaScript代码风格指南》,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
c语言中strcmp比较两个字符串的大小,两个字符串相同时返回0,第一个字符串大于第二个字符串时返回一个正值,否则返回负值。 比较两个字符串的算法是:逐个比较
一、问题描述给定两个字符串,求解这两个字符串的最长公共子序列(LongestCommonSequence)。比如字符串1:BDCABA;字符串2:ABCBDAB
PHPlevenshtein()函数实例计算两个字符串之间的Levenshtein距离:定义和用法levenshtein()函数返回两个字符串之间的Levens
下面为大家介绍用excel怎么检查两个字符串是否相同方法,步骤如下: 方法/步骤 一、数据准备。如图所示,这里有两个字符串1和2,现在需要判断两个字
在javascript中,正则表达式通常用于两个字符串方法:search()和replace()。search()方法用于检索字符串中指定的子字符串,或检索与正