欢迎您访问我爱IT技术网,今天小编为你分享的编程技术是:【PHP代码:基本数据结构和php内置函数】,下面是详细的分享!
PHP代码:基本数据结构和php内置函数
//--------------------
// 基本数据结构
//--------------------
|
以下为引用的内容: //二分查找(数组里查找某个元素)function bin_sch($array, $low, $high, $k){ if ($low <=$high){ $mid=intval(($low+$high)/2); if ($array[$mid]==$k){ return $mid; }elseif ($k < $array[$mid]){ return bin_sch($array, $low, $mid-1, $k); }else{ return bin_sch($array, $mid+1, $high, $k); } } return -1; } |
| //顺序查找(数组里查找某个元素) function seq_sch($array, $n, $k){ $array[$n]=$k; for($i=0; $i<$n; $i++){ if($array[$i]==$k){ break; } } if ($i<$n){ return $i; }else{ return -1; } } |
| //线性表的删除(数组中实现) function delete_array_element($array, $i) { $len=count($array); for ($j=$i; $j<$len; $j++){ $array[$j]=$array[$j+1]; } array_pop($array); return $array; } |
| //冒泡排序(数组排序) function bubble_sort($array) { $count=count($array); if ($count <=0) return false; for($i=0; $i<$count; $i++){ for($j=$count-1; $j>$i; $j--){ if ($array[$j] < $array[$j-1]){ $tmp=$array[$j]; $array[$j]=$array[$j-1]; $array[$j-1]=$tmp; } } } return $array; } |
| //快速排序(数组排序) function quicksort($array) { if (count($array) <=1) return $array; $key=$array[0]; $left_arr=array(); $right_arr=array(); for ($i=1; $i<count($array); $i++){ if ($array[$i] <=$key) $left_arr[]=$array[$i]; else $right_arr[]=$array[$i]; } $left_arr=quicksort($left_arr); $right_arr=quicksort($right_arr); return array_merge($left_arr, array($key), $right_arr); } |
//------------------------
// PHP内置字符串函数实现
//------------------------
|
以下为引用的内容: //字符串长度function strlen($str) { if ($str=='') return 0; $count=0; while (1){ if ($str[$count] !=NULL){ $count++; continue; }else{ break; } } return $count; } |
| //截取子串 function substr($str, $start, $length=NULL) { if ($str=='' || $start>strlen($str)) return; if (($length!=NULL) && ($start>0) && ($length>strlen($str)-$start)) return; if (($length!=NULL) && ($start<0) && ($length>strlen($str)+$start)) return; if ($length==NULL) $length=(strlen($str) - $start); if ($start < 0){ for ($i=(strlen($str)+$start); $i<(strlen($str)+$start+$length); $i++) { $substr .=$str[$i]; } } if ($length > 0){ for ($i=$start; $i<($start+$length); $i++) { $substr .=$str[$i]; } } if ($length < 0){ for ($i=$start; $i<(strlen($str)+$length); $i++) { $substr .=$str[$i]; } } return $substr; } |
| //字符串翻转 function strrev($str) { if ($str=='') return 0; for ($i=(strlen($str)-1); $i>=0; $i--){ $rev_str .=$str[$i]; } return $rev_str; } |
| //字符串比较 function strcmp($s1, $s2) { if (strlen($s1) < strlen($s2)) return -1; if (strlen($s1) > strlen($s2)) return 1; for ($i=0; $i<strlen($s1); $i++){ if ($s1[$i]==$s2[$i]){ continue; }else{ return false; } } return 0; } |
| //查找字符串 function strstr($str, $substr) { $m=strlen($str); $n=strlen($substr); if ($m < $n) return false; for ($i=0; $i<=($m-$n+1); $i++){ $sub=substr($str, $i, $n); if (strcmp($sub, $substr)==0) return $i; } return false; } |
| //字符串替换 function str_replace($substr, $newsubstr, $str) { $m=strlen($str); $n=strlen($substr); $x=strlen($newsubstr); if (strchr($str, $substr)==false) return false; for ($i=0; $i<=($m-$n+1); $i++){ $i=strchr($str, $substr); $str=str_delete($str, $i, $n); $str=str_insert($str, $i, $newstr); } return $str; } |
//--------------------
// 自实现函数
//--------------------
|
以下为引用的内容: //插入一段字符串function str_insert($str, $i, $substr) { for($j=0; $j<$i; $j++){ $startstr .=$str[$j]; } for ($j=$i; $j<strlen($str); $j++){ $laststr .=$str[$j]; } $str=($startstr . $substr . $laststr); return $str; } |
|
//删除一段字符串 function str_delete($str, $i, $j) { for ($c=0; $c<$i; $c++){ $startstr .=$str[$c]; } for ($c=($i+$j); $c<strlen($str); $c++){ $laststr .=$str[$c]; } $str=($startstr . $laststr); return $str; } |
| //复制字符串 function strcpy($s1, $s2) { if (strlen($s1)==NULL || !isset($s2)) return; for ($i=0; $i<strlen($s1); $i++){ $s2[]=$s1[$i]; } return $s2; } |
| //连接字符串 function strcat($s1, $s2) { if (!isset($s1) || !isset($s2)) return; $newstr=$s1; for($i=0; $i<count($s); $i++){ $newstr .=$st[$i]; } return $newsstr; } |
| //简单编码函数(与php_decode函数对应) function php_encode($str) { if ($str=='' && strlen($str)>128) return false; for($i=0; $i<strlen($str); $i++){ $c=ord($str[$i]); if ($c>31 && $c<107) $c +=20; if ($c>106 && $c<127) $c -=75; $word=chr($c); $s .=$word; } return $s; } |
| //简单解码函数(与php_encode函数对应) function php_decode($str) { if ($str=='' && strlen($str)>128) return false; |
for($i=0; $i<strlen($str); $i++){
$c=ord($word);
if ($c>106 && $c<127) $c=$c-20;
if ($c>31 && $c<107) $c=$c+75;
$word=chr($c);
$s .=$word;
}
return $s;
}
| //简单加密函数(与php_decrypt函数对应) function php_encrypt($str) { $encrypt_key='abcdefghijklmnopqrstuvwxyz1234567890'; $decrypt_key='ngzqtcobmuhelkpdawxfyivrsj2468021359'; if (strlen($str)==0) return false; for ($i=0; $i<strlen($str); $i++){ for ($j=0; $j<strlen($encrypt_key); $j++){ if ($str[$i]==$encrypt_key[$j]){ $enstr .=$decrypt_key[$j]; break; } } } return $enstr; } |
| //简单解密函数(与php_encrypt函数对应) function php_decrypt($str) { $encrypt_key='abcdefghijklmnopqrstuvwxyz1234567890'; $decrypt_key='ngzqtcobmuhelkpdawxfyivrsj2468021359'; if (strlen($str)==0) return false; for ($i=0; $i<strlen($str); $i++){ for ($j=0; $j<strlen($decrypt_key); $j++){ if ($str[$i]==$decrypt_key[$j]){ $enstr .=$encrypt_key[$j]; break; } } } return $enstr; } |
以上所分享的是关于PHP代码:基本数据结构和php内置函数,下面是编辑为你推荐的有价值的用户互动:
相关问题:如何才能查看PHP内置函数源代码
答:进入php源程序目录中的ext目录中,这里存放着各个扩展模块的源代码,选择你需要的模块,比如curl模块:cd curl 执行phpize生成编译文件,phpize在PHP安装目录的bin目录下 /usr/local/php5/bin/phpize 运行时,可能会报错:Cannot find autoconf.... >>详细
相关问题:PHP数据结构和算法学习求指点
答:C语言是所有高级编程语言的入门语言,所以数据结构中算法一般都使用C语言来表示,这样大家都能看懂。学习数据结构和算法是与语言无关的,C语言只是它实现的一种方式,不用太在乎的。建议你把C语言的基础知识学习一下,这样看起来就不会太累了。 >>详细
相关问题:PHP语言做网页开发,会用到什么数据结构,算法
答:数据结构 一般的 网页 网站开发都是用不到的 只有在 数据分析 数据挖掘 之类的网站才会使用到 算法 简单的排序算法 堆栈实现 还是要了解一下 不过 这些在php中都有内置的实现,直接调用函数也就可以 高级的算法 我也不会 >>详细
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
