数据结构——树小记

数据结构——树小记

简介

二叉树

  1. 普通二叉树
  2. 二叉查找树

平衡树

  1. 平衡二叉树 AVL
  2. B-Tree
  3. B+Tree
  4. R-B-Tree

平衡树

AVL

关键

平衡因子,旋转

ps:新增或删除,导致高度变更,需向上递归检查,避免失衡

旋转

类型:LL、LR、RR、RL

  1. LR:先左旋后右旋
  2. LL:左旋
插入
  1. 定位到叶子,插入
  2. 更新高度
  3. 平衡调整:计算当前节点高度差,旋转保持平衡,向上递归检测
删除
删除叶子
  1. 定位删除
  2. 向上递归检测
删除单孩子
  1. 定位删除
  2. 孩子顶替
  3. 向上递归检测
删除双孩子
  1. 定位
  2. 找到直接前驱或后继叶子,值替换
  3. 改变指向实现删除叶子
  4. 向上递归检测
B-Tree
关键

m阶

节点和节点内实体:

class Entry {
    K key;
    V value;
}

class Node {
    Entry[] entries;
    Node[] children;
    boolean isLeaf;
}
分裂
  1. 定位节点内中间key
  2. 上传给父节点
  3. 递归处理父节点
重平衡
  1. 相邻兄弟节点有多余key,旋转
  2. 兄弟无多余,则父key下降合并,递归处理父节点
插入
  1. 定位到叶子,插入
  2. 多则分裂
删除
非叶子节点
  1. 定位
  2. 找到直接前驱/后继节点key
  3. 替换,转变为删除叶子节点
叶子节点
  1. 定位删除
  2. 少则重平衡

B+Tree

比起B-Tree:

  1. 非叶子作为索引层,保存key
  2. 叶子作为存储层,保存key和value,且节点间组成链表

红黑树(略)

关键
  1. 节点颜色:红或黑
  2. 根:黑
  3. (NIL)叶子:黑
  4. 一个红色节点,子节点为黑色
  5. 节点到子孙节点的路径,包含相同黑色节点
平衡手段
  1. 旋转
  2. 染色
添加
  1. 定位插入
  2. 着红
  3. 平衡
删除
  1. 定位删除(包含删除叶子、删除单孩子非叶子、删除双孩子非叶子,同上处理)
  2. 平衡
接入第三方登录是让用户方便快捷地使用已有账号登录你的网站或应用程序,提高用户体验的一种方式。本文将介绍如何使用 PHP 实现微信公众号第三方登录。 1. 获取微信授权 首先,需要获取微信用户的授权。具体步骤如下: 1)引导用户打开微信授权页面: ```php $appid = 'your_appid'; $redirect_uri = urlencode('http://yourdomain.com/callback.php'); $scope = 'snsapi_userinfo'; $url = "https://open.weixin.qq.com/connect/oauth2/authorize?appid=$appid&redirect_uri=$redirect_uri&response_type=code&scope=$scope&state=STATE#wechat_redirect"; header("Location: $url"); ``` 其中,`$appid` 是你的微信公众号的 AppID,`$redirect_uri` 是授权后回调的 URL,`$scope` 是授权作用域,可以是 `snsapi_base` 或 `snsapi_userinfo`,`$state` 是自定义参数,用于防止 CSRF 攻击。 2)获取授权码: 用户同意授权后,会重定向到 `$redirect_uri` 指定的 URL,带上授权码 `code` 和 `state` 参数。 ```php $code = $_GET['code']; $state = $_GET['state']; ``` 3)获取 access_token 和 openid: 使用授权码 `code` 获取 `access_token` 和 `openid`。 ```php $access_token_url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=$appid&secret=$secret&code=$code&grant_type=authorization_code"; $response = file_get_contents($access_token_url); $result = json_decode($response, true); $access_token = $result['access_token']; $openid = $result['openid']; ``` 其中,`$secret` 是你的微信公众号的 AppSecret。 2. 获取用户信息 获取到 `access_token` 和 `openid` 后,可以使用以下代码获取用户信息: ```php $userinfo_url = "https://api.weixin.qq.com/sns/userinfo?access_token=$access_token&openid=$openid&lang=zh_CN"; $response = file_get_contents($userinfo_url); $userinfo = json_decode($response, true); ``` 其中,`$userinfo` 包含用户的昵称、头像等信息。 3. 将用户信息保存到数据库 最后,将获取到的用户信息保存到数据库中,以便下次使用时快速登录。 ```php // 连接数据库 $con = mysqli_connect('localhost', 'username', 'password', 'database'); mysqli_set_charset($con, "utf8"); // 查询用户是否已存在 $sql = "SELECT * FROM users WHERE openid='$openid'"; $result = mysqli_query($con, $sql); if (mysqli_num_rows($result) == 0) { // 用户不存在,插入新用户信息 $nickname = mysqli_real_escape_string($con, $userinfo['nickname']); $headimgurl = mysqli_real_escape_string($con, $userinfo['headimgurl']); $sql = "INSERT INTO users (openid, nickname, headimgurl) VALUES ('$openid', '$nickname', '$headimgurl')"; mysqli_query($con, $sql); } // 保存用户登录状态 $_SESSION['openid'] = $openid; ``` 以上就是使用 PHP 实现微信公众号第三方登录的步骤。需要注意的是,为了确保安全性,应该对用户输入的数据进行过滤和验证,防止 SQL 注入和 XSS 攻击等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值