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 

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

if( $array[$i]==$k){

break;

}

}

if ($i

return  $i;

}else{

return -1;

}

}

//线性表的删除(数组中实现)

function delete_array_element($array , $i)

{

$len =  count($array);

for ($j= $i; $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

for($j=$count-1 ; $j>$i; $j--){

if ($array[$j] 

$tmp = $array[$j];

$array[$j] = $array[ $j-1];

$array [$j-1] = $tmp;

}

}

}

return $array;

}

//快速排序(数组排序)

function quick_sort($array ) {

if (count($array) <= 1) return  $array;

$key = $array [0];

$left_arr  = array();

$right_arr = array();

for ($i= 1; $i

if ($array[ $i] <= $key)

$left_arr [] = $array[$i];

else

$right_arr[] = $array[$i ];

}

$left_arr = quick_sort($left_arr );

$right_arr = quick_sort( $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) && ($startstrlen($str )+$start)) return;

if ($length ==  NULL) $length = (strlen($str ) - $start);

if ($start 

for ($i=(strlen( $str)+$start); $i

$substr .=  $str[$i];

}

}

if ($length  > 0){

for ($i= $start; $i

$substr  .= $str[$i];

}

}

if ( $length 

for ($i =$start; $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) 

if (strlen($s1) > strlen( $s2)) return 1;

for ($i =0; $i

if ($s1[ $i] == $s2[$i]){

continue;

}else{

return false;

}

}

return  0;

}

//查找字符串

function  strstr($str, $substr)

{

$m = strlen($str);

$n = strlen($substr );

if ($m 

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

$startstr .= $str[$j ];

}

for ($j=$i; $j 

$laststr .= $str[$j ];

}

$str = ($startstr . $substr  . $laststr);

return $str ;

}

//删除一段字符串

function str_delete($str , $i, $j)

{

for ( $c=0; $c

$startstr .= $str [$c];

}

for ($c=( $i+$j); $c

$laststr  .= $str[$c];

}

$str = ($startstr . $laststr );

return $str;

}

//复制字符串

function strcpy($s1, $s2 )

{

if (strlen($s1)==NULL || !isset( $s2)) return;

for ($i=0 ; $i

$s2[] = $s1 [$i];

}

return $s2;

}

//连接字符串

function strcat($s1 , $s2)

{

if (!isset($s1) || !isset( $s2)) return;

$newstr = $s1 ;

for($i=0; $i 

$newstr .= $st[$i ];

}

return $newsstr;

}

//简单编码函数(与php_decode函数对应)

function php_encode($str)

{

if ( $str=='' && strlen( $str)>128) return false;

for( $i=0; $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

$c  = ord($word);

if ( $c>106 && $c<127 ) $c = $c-20;

if ($c>31 && $c

$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

for ($j=0; $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

for ($j=0; $j 

if ($str[$i] == $decrypt_key [$j]){

$enstr .=  $encrypt_key[$j];

break;

}

}

}

return $enstr;

}

?>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/564220.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++ 运算符重载规则

运算符重载是通过函数重载实现的&#xff0c;下面我们来介绍一下运算符重载需要遵循的规则。 1 并不是所有的运算符都可以重载。能够重载的运算符包括&#xff1a; - * / % ^ & | ~ ! < > - * / % ^ & | << >> << &…

C++ 重载数学运算符

四则运算符&#xff08;、-、、/、、-、、/&#xff09;和关系运算符&#xff08;>、<、<、>、、!&#xff09;都是数学运算符&#xff0c;它们在实际开发中非常常见&#xff0c;被重载的几率也很高&#xff0c;并且有着相似的重载格式。 复数能够进行完整的四则运…

php 隐藏 div 代码,在HTML里用CSS隐藏div的方法

我们知道&#xff0c;在制作网页的过程中常常会想隐藏一些内容&#xff0c;比如网站添加第三方统计显示的图标等&#xff0c;如何通过CSS隐藏&#xff0c;怎么让图片作为背景&#xff0c;但文字又不显示呢&#xff1f;这篇文章来给大家解读一下。一、普通隐藏网页内容CSS样式单…

php+错误+处理,PHP 错误处理手记!!!!!

header("content-type:text/html;charsetutf-8");/**定义errror_handler函数作为set_error_handler()的第一个参数回调;param int $error_level 错误级别param string $error_message 错误信息param string $file 错误所在文件param int $line 错误所在行*/function …

网络第3天

基于UDP的TFTP文件传输 功能&#xff1a;下载、上传、退出 #include <myhead.h> #define IP "192.168.8.100" #define PORT 69 int download_file(int…

C++ 重载左移和右移运算符

C中&#xff0c;标准库本身已经对左移运算符<<和右移运算符>>分别进行了重载&#xff0c;使其能够用于不同数据的输入输出&#xff0c;但是输入输出的对象只能是 C 内置的数据类型&#xff08;例如 bool、int、double 等&#xff09;和标准库所包含的类类型&#x…

怎么用java跟数据库建立关系,java – 关系和构建数据库

请尝试以下方法&#xff1a;我认为它涵盖了你所有的设计要点.我试图在您的评论之间进行阅读,我认为您希望实现一个系统,您可以在其中捕获一些“规则”以供审核(我猜测,但示例可能是评论可以达到n在评论获得一定程度的质量之前,必须至少有m个顾客评论.如果确实如此,我创建了一个…

C++重载下标运算符

C 规定&#xff0c;下标运算符[ ]必须以成员函数的形式进行重载。该重载函数在类中的声明格式如下&#xff1a; 返回值类型 & operator[ ] (参数);或者&#xff1a; const 返回值类型 & operator[ ] (参数) const;使用第一种声明方式&#xff0c;[ ]不仅可以访问元素…

php 表情选择,php imagettftext和特定的表情符号

我遇到了一个问题,绘制了“杂项符号和象形文字”unicode块下的表情符号.这是一个示例代码&#xff1a;header(Content-Type: image/png);$im imagecreatetruecolor(290, 60);$grey imagecolorallocate($im, 200, 200, 200);$black imagecolorallocate($im, 0, 0, 0);imagefi…

C++ 重载自增和自减运算符

自增和自减–都是一元运算符&#xff0c;它的前置形式和后置形式都可以被重载。请看下面的例子&#xff1a; #include <iostream> #include <iomanip> using namespace std;//秒表类 class stopwatch{ public:stopwatch(): m_min(0), m_sec(0){ } public:void set…

java写一个类吧,能不能自己写个java自带的类

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼11.interface Playable {void play();}interface Bounceable {void play();}interface Rollable extends Playable, Bounceable {Ball ball new Ball("PingPang");}class Ball implements Rollable {private String nam…

C++ 重载new和delete运算符

内存管理运算符 new、new[]、delete 和 delete[] 也可以进行重载&#xff0c;其重载形式既可以是类的成员函数&#xff0c;也可以是全局函数。一般情况下&#xff0c;内建的内存管理运算符就够用了&#xff0c;只有在需要自己管理内存时才会重载。 以成员函数的形式重载 new 运…

matlab电机标定,基于模型的电机标定及高精度电机建模

概述在新能源汽车测试领域中&#xff0c;新能源汽车的驱动电机控制电流需要进行台架标定&#xff0c;目前电机台架标定中控制电流的标定是通过手动方式进行的&#xff0c;手动标定电机控制电流&#xff0c;对匹配工程师的技术要求高、工作强度大、标定周期长、标定精度也不够理…

C++ 重载强制类型转换运算符

C 中&#xff0c;类型的名字&#xff08;包括类的名字&#xff09;本身也是一种运算符&#xff0c;即类型强制转换运算符。 类型强制转换运算符是单目运算符&#xff0c;也可以被重载&#xff0c;但只能重载为成员函数&#xff0c;不能重载为全局函数。经过适当重载后&#xf…

滑动加载怎么做 php,vue之UI框架如何实现滑动加载数据

在我们移动端还有一个很常用的组件&#xff0c;那就是滑动加载更多组件。平常我们看到的很多插件实现相当复杂就觉得这个组件很难&#xff0c;其实不是的&#xff01;&#xff01;这个组件其实可以很简单的就实现出来&#xff0c;而且体验也能非常的棒(当然我们没有实现下拉刷新…

EasyX的安装与使用详细教程

EasyX 是针对 C/C 的图形库&#xff0c;可以帮助使用C/C语言的程序员快速上手图形和游戏编程&#xff0c;可以用来做些简单的演示2d类游戏&#xff0c;没有cocos2d-x那样重量级&#xff0c;学习起来也比较简单。 安装 1 . 打开Easyx官网https://easyx.cn/下载 EasyX&#xff…

二维码图片解码

二维码图片解码 现在进入了快节奏的时代&#xff0c;已经没有什么是扫码解决不了的了&#xff0c;我们光知道二维码是远远不能满足我们的需求的&#xff0c;我们需要知道二维码所表示的地址&#xff0c;但是有什么办法可以让我们对二维码进行解析然后获得地址的呢&#xff1f;…

php 删除整个目录,php 删除整个目录功能实例

这篇文章主要为大家详细介绍了php 删除整个目录功能实例&#xff0c;具有一定的参考价值&#xff0c;可以用来参考一下。对php删除整个目录的代码感兴趣的小伙伴&#xff0c;下面一起跟随512笔记的小编两巴掌来看看吧&#xff01;/*** php删除整个目录的代码** param* author 五…

C++ 强制类型转换运算符

C 将类型名作为强制类型转换运算符。 C 引入了四种功能不同的强制类型转换运算符以进行强制类型转换&#xff1a;static_cast、reinterpret_cast、const_cast 和 dynamic_cast。 强制类型转换是有一定风险的&#xff0c;有的转换并不一定安全&#xff0c;如把整型数值转换成指…

r语言如何读取matlab数据类型,[转载]R语言数据类型解析[转]

寻求帮助&#xff0c;使用 help(solve)&#xff0c;?solve 和 help(“solve”)是一样的&#xff0c;如果需要搜索可以用help.search(solve) 或者 ??solve。另外使用 help.start() 可以打开网页版的帮助&#xff0c;这个功能倒是和Matlab 的 doc 有几分相似。使用 source() 和…