#### 冒泡排序
$a=array(9,3,4,5,7,4,2,6);
$n=count($a); //个数
for($i=0; $i<$n-1; ++$i) {
for($k=0; $k<$n-$i-1; ++$k) {
if($a\[$k\]>$a\[$k+1\]) {
$t=$a\[$k\]; $a\[$k\]=$a\[$k+1\]; $a\[k+1\]=$t;
}
}
}
#### 选择排序
求得一个数组的最大值的下标,并将这个最大值下标的单元跟最后一个单元进行交换;
然后,继续从剩余数据中取得最大值的下标,并将这个最大值下标的单元跟剩余的最后一个单元交换以此类推
$a=array(9,3,4,5,7,4,2,6);
$n=count($a); //个数
for($i=0; $i<$n-1; ++$i) {
$max=$a\[0\]; //找最大值先要取得第一项的值
$pos=0; //找最大值下标,也要先取得第一项的下标
for($k=0; $k<$n-$i; ++$k) {
if($a\[$k\] > $max) {
$max=$a\[$k\]; $pos=$k;
}
}
$t=$a\[$pos\]; //最大单元的值
$a\[$pos\]=$a\[$n-$i-1\]; //$n-$i-1就是剩余数据中的最后一个单元的下标
$a\[$n-$i-1\]=$t;
}
#### 二分查找法
前提:针对的是索引数组,针对的是已经排好序的数组
//$arr要查找的数组,$s要找的数字,$begin开始位置,$end结束位置
function binary\_search($arr, $s, $begin, $end) {
$mid=floor( ($begin+$end)/2 ); //定位中间的位置
$mid\_value=$arr\[$mid\]; //取得中间项的值
if($mid\_value == $s) {
return true;
}
else if($mid\_value > $s) {
if($begin > $mid-1) { //如果开始位置都比结束位置大了
return false;
}
$re=binary\_search($arr, $s, $begin, $mid-1); //中间项比要找的$s大,就去左边找
}
else {
if($mid+1 > $end) { //如果开始位置都比结束位置大了,表示找不到了
return false
}
$re=binary\_search($arr, $s, $begin, $mid-1); //中间项比要找的$s小,就去右边找
}
return $re;
}
- PHP
- 页面跳转
- 数据类型和运算符
- 整形
- 浮点型
- 字符串型
- 布尔型
- 判断数据类型
- 传值
- 类型转换
- 常量
- 进制转换
- 运算符
- 各种结构
- 数组
- 分类
- 创建
- 多维数组
- 数组操作函数
- 数组指针
- 排序
- 数组交换需要注意的
- 函数
- 创建函数
- 参数传递
- 参数数量问题
- 返回值
- 可变函数
- 匿名函数
- 冒泡,选择,二分
- 变量的作用域
- 局部作用域中使用全局
- use
- 有关函数的系统函数
- 递归
- 递推(迭代)
- 面向对象
- 类和对象
- 值传递
- 引用传递
- 成员
- 构造和析构调用上级同类方法
- 重写
- 最终类
- 最终方法
- 设计模式
- 抽象类
- 抽象方法
- 抽象类和抽象方法的细节
- 重载
- 接口
- 类和接口的总结
- 自动加载
- 克隆
- 对象的遍历
- 内置标准类
- 其他类型转对象类型
- 类型约束
- 魔术方法
- static关键字
- 命名空间
- 子级空间
- 引入机制
- 公共空间
- 使用注意
- 错误处理
- 错误的触发
- 错误报告的显示
- 错误日志的记录问题
- 自定义错误处理器
- 异常抛出
- 文件锁
- 文件处理
- 序列化与反序列化
- 目录操作
- 文件操作
- 文件上传
- $_FILFS
- 多文件上传处理
- 绘图技术
- 创建画布资源
- 操作画布
- 导出
- 销毁资源
- 验证码
- 补充文件居中
- 在图像上写入一行TTF字体的文本
- 获得图像相关信息
- 水印
- 等比例缩放
- 常见错误
- HTTP协议
- URL的构成
- 请求
- 防盗链
- 响应
- 使用header()禁用缓存
- 下载文件的HTTP响应头
- 文件下载
- HTTPS
- 会话技术
- cookie
- session
- PHP操作MySQL函数
- 登录
- 一些函数
- 从结果集中取出一行数据
- 获取行数,列数,字段名
- 安全
- 缓存
- 补充
- MySQL
- 语法
- 备份和恢复
- 注释
- 语句行
- 字符集
- 校验级
- 存储引擎
- 数据库操作
- 创建数据库
- 删除数据库
- 显示数据库
- 修改数据库
- 数据类型
- 整数类型
- 小数类型
- 日期时间型
- 字符和文本型
- enum类型
- set类型
- 时间类型
- 表操作
- 创建
- 索引
- 约束
- 表选项列表
- 表的其他语句
- 视图语法
- 增删改查
- 插入数据(增)
- 删除数据(删)
- 修改数据(改)
- 查询(查)
- 用户和权限管理
- 用户管理
- 权限管理
- PDO
- 与PDO相关的几个类
- 连接数据库
- 使用
- PDO的错误处理
- PDO结果集对象
- pdo结果集对象的常用方法
- PDO预处理
- 常用属性
- mysql编程
- 事务
- 语句块
- mysql中的变量
- (存储)函数
- 存储过程procedure
- 触发器(trigger)
- mysql优化
- 存储引擎
- 字段类型
- 逆范式
- 索引
- Memcache
- 与redis区别
- 安装
- php开启扩展
- php操作memcache
- Key的命名
- 有效期
- 各种数据类型存储
- 删除
- 第三个参数压缩作用
- 其他相关操作方法
- 终端命令操作方式
- 获取memcache统计信息
- Git
- 创建一个git仓库
- 添加
- 修改文件
- 删除文件
- 克隆
- 个人网站
- Ajax
- 发起请求
- 接受响应
- 常用属性和方法
- get和post
- get
- post
- 同步和异步
- 什么时候使用同步请求?
- 分页
- xml的接收和处理
- JSON
- 无刷新表单提交和进度条
- JQuery操作ajax
- iframe
- 邮件
- 介绍
- 发送邮件
- 直投邮件
- 中转邮件发送
- phpmailer
- 正则表达
- 简单使用
- preg_match()
- 正则内容
- 定义字符集
- 特别字符集
- 组合字符集
- 限制字符
- 模式修正符
- 进行全局匹配