词条 | 暴力法 |
释义 | 暴力法,又叫蛮力法,算法的一种。 英文:brute force 广义的暴力法利用枚举所有的情况,或者其它大量运算又不用技巧的方式,来求解问题的方法。 广义的暴力法在解决问题,特别是数学和计算机编程问题方面应用广泛,有着巨大的作用。它的缺点是效率低下,优点是编码复杂度低,几乎不用思考,不容易出错。 例如:判断一个正整数n是不是素数。 用这个数除以2到n-1之间的数,如果都不能整除就是素数,否则不是素数。这种方法是暴力法。而利用其它方法,如Rabin-Miller等方法判定就不是暴力法。 狭义的暴力法这是一种简单的串匹配算法,用来判断一个短串t是不是一个长串s的子串。 过程很简单,就是从s的第一个元素和t的第一个元素开始比较,如果相同则比较下一个。不相同则t返回到第一个元素,s回到上次开始位置的下一个位置,继续比较。如果出现一个和t全部相同的,就匹配成功。如果s到结尾都没有,就匹配失败。 过程: 1.i指向s[]的第一个元素,j指向t[]的第一个元素。 2.如果s[i]等于t[j],进行第3步;否则进行5步。 3.i和j都向后移动一位。 4.如果到达t[]的结尾,匹配成功,返回子串位置;否则进行第2步。 5.i向后移动一位,j回到开头元素。 6.如果到达s[]的结尾,返回失败;否则进行第2步。 C语言代码: int bruteforce(char s[],char t[]) { int i,j; for(i=0;s[i]!='\\0';i++) { j=0; while(s[i+j]==t[j]) { j++; if(t[j]=='\\0') //到达t[]的结尾,返回成功匹配的位置 return i; } } return -1; //返回失败 } |
随便看 |
百科全书收录4421916条中文百科知识,基本涵盖了大多数领域的百科知识,是一部内容开放、自由的电子版百科全书。