php實(shí)現(xiàn)的簡(jiǎn)單壓縮英文字符串的代碼
更新時(shí)間:2008年04月24日 19:28:45 作者:
一直在找壓縮字符串的算法,
不知道是不是關(guān)鍵詞選擇的不對(duì),
找不到適合的,自己寫(xiě)了一對(duì)連續(xù)字符壓縮,(如 vvvv -> 4v)
不過(guò)實(shí)用效果不太好(壓縮比低,效率卻不高),
暫且丟上來(lái)曬曬吧
PHP,適應(yīng)于上帖簡(jiǎn)單加密后的密文
<?php
//replacement來(lái)自上個(gè)版本的加密替換
function compress_func($match) {return strlen($match[0]).$match[0]{0};}
function uncompress_func($match) {return str_repeat($match[2], $match[1]);}
function compress($str) {
$i = 0;
$pattern = array();
while(isset($replacement{$i})) array_push($pattern, "/".$replacement{$i++}."{2,}/");
return preg_replace_callback($pattern, "compress_func", $str);
}
function uncompress($str) {
return preg_replace_callback("/(d+)(w)/", "uncompress_func", $str);
}
?>
AWK,通用格式
#!/bin/awk
function compress(str, _ARGVEND_, str_out, str_len, i, s, l) {
str_out = "";
str_len = length(str);
s = "";
l = 1;
for(i =1; i <= str_len; i++) {
if(substr(str, i, 1) == s) l++;
else {
if(s != "") {
if(l > 1) str_out=str_out""l
str_out=str_out""s;
}
s = substr(str, i, 1);
l = 1;
}
}
return str_out;
}
function uncompress(str, _ARGVEND_, str_out, str_len, i, c) {
str_out = "";
str_len = length(str);
for(i =1; i <= str_len; i++) {
c = 0;
while(substr(str, i, 1)~/[0-9]/) {
c = c*10+substr(str, i, 1);
i++;
}
if(c < 1) c = 1;
while(c--) str_out = str_out""substr(str, i, 1);
}
return str_out;
}
復(fù)制代碼 代碼如下:
<?php
//replacement來(lái)自上個(gè)版本的加密替換
function compress_func($match) {return strlen($match[0]).$match[0]{0};}
function uncompress_func($match) {return str_repeat($match[2], $match[1]);}
function compress($str) {
$i = 0;
$pattern = array();
while(isset($replacement{$i})) array_push($pattern, "/".$replacement{$i++}."{2,}/");
return preg_replace_callback($pattern, "compress_func", $str);
}
function uncompress($str) {
return preg_replace_callback("/(d+)(w)/", "uncompress_func", $str);
}
?>
AWK,通用格式
復(fù)制代碼 代碼如下:
#!/bin/awk
function compress(str, _ARGVEND_, str_out, str_len, i, s, l) {
str_out = "";
str_len = length(str);
s = "";
l = 1;
for(i =1; i <= str_len; i++) {
if(substr(str, i, 1) == s) l++;
else {
if(s != "") {
if(l > 1) str_out=str_out""l
str_out=str_out""s;
}
s = substr(str, i, 1);
l = 1;
}
}
return str_out;
}
function uncompress(str, _ARGVEND_, str_out, str_len, i, c) {
str_out = "";
str_len = length(str);
for(i =1; i <= str_len; i++) {
c = 0;
while(substr(str, i, 1)~/[0-9]/) {
c = c*10+substr(str, i, 1);
i++;
}
if(c < 1) c = 1;
while(c--) str_out = str_out""substr(str, i, 1);
}
return str_out;
}
相關(guān)文章
基于PHP實(shí)現(xiàn)短信驗(yàn)證碼接口(容聯(lián)運(yùn)通訊)
本文分步驟給大家講解了短信驗(yàn)證碼接口(容聯(lián)運(yùn)通訊)實(shí)現(xiàn)代碼,非常不錯(cuò),具有參考借鑒價(jià)值,感興趣的朋友一起看看吧2016-09-09
實(shí)用的簡(jiǎn)單PHP分頁(yè)集合包括使用方法
收集了三個(gè)PHP分頁(yè)方法,總會(huì)有一個(gè)適合你用的。2013-10-10
Yii2.0高級(jí)框架數(shù)據(jù)庫(kù)增刪改查的一些操作
yii2.0框架是PHP開(kāi)發(fā)的一個(gè)比較高效率的框架,集合了作者的大量心血,下面通過(guò)用戶(hù)為例給大家詳解yii2.0高級(jí)框架數(shù)據(jù)庫(kù)增刪改查的一些操作2015-11-11
YII2框架中使用yii.js實(shí)現(xiàn)的post請(qǐng)求
本文給大家介紹的是簡(jiǎn)單分析下用yii2的yii\helpers\Html類(lèi)和yii.js實(shí)現(xiàn)的post請(qǐng)求的方法,非常的簡(jiǎn)單,有需要的小伙伴可以參考下2017-04-04
PHP簡(jiǎn)單的MVC框架實(shí)現(xiàn)方法
在PHP中使用MVC越來(lái)越流行了,特別是在一些開(kāi)源的框架當(dāng)中。本篇給大家介紹php簡(jiǎn)單的mvc框架實(shí)現(xiàn)方法,對(duì)php簡(jiǎn)單的mvc框架相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2015-12-12
國(guó)產(chǎn)PHP開(kāi)發(fā)框架myqee新手快速入門(mén)教程
這篇文章主要介紹了國(guó)產(chǎn)PHP開(kāi)發(fā)框架myqee新手快速入門(mén)教程,myqee中文名稱(chēng)邁啟PHP框架,有比較多的高級(jí)開(kāi)發(fā)特性,需要的朋友可以參考下2014-07-07
laravel5.6 框架操作數(shù)據(jù) Eloquent ORM用法示例
這篇文章主要介紹了laravel5.6 框架操作數(shù)據(jù) Eloquent ORM用法,結(jié)合實(shí)例形式詳細(xì)分析了laravel5.6 框架使用Eloquent ORM操作數(shù)據(jù)增刪改查相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2020-01-01
Yii使用migrate命令執(zhí)行sql語(yǔ)句的方法
這篇文章主要介紹了Yii使用migrate命令執(zhí)行sql語(yǔ)句的方法,結(jié)合實(shí)例形式分析了Yii命令工具migrate的具體使用技巧,需要的朋友可以參考下2016-03-03

