国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Regex > 正文

正則表達(dá)式解二元方程式代碼

2020-03-16 21:09:10
字體:
供稿:網(wǎng)友
看到了這文我震驚了,正則能解二元方程式~~,需要的朋友可以看下
 
 

原文:http://blog.stevenlevithan.com/archives/algebra-with-regexes
我照著原文寫出的正則還真的計(jì)算出了結(jié)果。上php例子:

復(fù)制代碼代碼如下:

<?php
/**
 * 計(jì)算 Ax+By=C
 */
function suan($A, $B, $C) {
 $A--;
 $B--;
 $str = str_repeat('-', $C);
 $search = '/^(.*)/1{' . $A . '}(.*)/2{' . $B . '}$/';
 preg_match($search, $str, $r);
 return array('x' => strlen($r[1]), 'y' => strlen($r[2]));

$A = 2;
$B = 3;
$C = 9;
$r = suan($A, $B, $C);
// 測試
echo '計(jì)算' . $A . 'x+' . $B . 'y=' . $C . '<br />';
echo 'x=' . ($r[x]) . '<br />';
echo 'y=' . ($r[y]);
// 輸出
// 計(jì)算2x+3y=9
// x=3
// y=1
?>

我解釋下
來一個(gè)簡單的式子來說:2x+3y=9

原理:
在此函數(shù)中生成出這樣的正則
復(fù)制代碼代碼如下:
^(.*)/1{1}(.*)/2{2}$

去匹配一個(gè)長度為9的重復(fù)字符串 “-”,匹配出兩個(gè)分組的長度,就是他的x   和  y的值了

正則解釋:
【(.*)】也就是0到無數(shù)個(gè)【.】點(diǎn)號(hào)。
/1就是引用一組。后面【{1}】就是重復(fù)1次。
后半是/2就是引用2組。后面【{2}】就是重復(fù)1次。
以下是那個(gè)英文博客的翻譯:
二元方程17x + 12y = 51,其表達(dá)式【^(.*)/1{16}(.*)/2{11}$】。很好理解。【(.*)】也就是0到無數(shù)個(gè)【.】點(diǎn)號(hào)。(這里是接著上文說的,其實(shí),【.】點(diǎn)號(hào)想表示的是字符“1”)
也就是0到無數(shù)個(gè)1,后面【/1】引用一次。后面【{16}】就是16次。作用于前面的【/1】,也就是16次引用。加上開始的【(.*)】一共正好17次。后面一個(gè)就不說了,跟這個(gè)一樣。
正則引擎會(huì)依次嘗試【(.*)】中0到無數(shù)個(gè)字符“1”,0個(gè)字符“1”,1個(gè)字符“1”,2個(gè)字符“1”一直增加的嘗試。直到成功,否則要嘗試完所有字符“1”的最大個(gè)數(shù)(這里是51個(gè)字符“1”)。

 

PS: 沒有考慮無解的情況,當(dāng)無解時(shí) x和y都是0


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 章丘市| 永城市| 河津市| 云浮市| 翁源县| 桐柏县| 射阳县| 沙湾县| 武穴市| 汾阳市| 平凉市| 镇江市| 嘉定区| 大悟县| 宁国市| 炎陵县| 民权县| 韩城市| 紫阳县| 连平县| 石城县| 双柏县| 江北区| 林周县| 静海县| 巴楚县| 禹城市| 安西县| 容城县| 漯河市| 博乐市| 淄博市| 莱阳市| 高密市| 白城市| 鄂伦春自治旗| 壤塘县| 宁安市| 麟游县| 宜都市| 布尔津县|