树的存储和遍历

news2025/1/9 9:50:44

文章目录

    • 6.5 树与森林
      • 6.5.1 树的存储结构
        • 1. 双亲表示法(顺序存储结构)
        • 2 孩子链表表示法
        • 3 孩子兄弟表示法(二叉树表示法)
      • 6.5.2 森林与二叉树的转换
        • 1 树转换成二叉树
        • 2 二叉树转换成树
        • 3 森林转换成二叉树
        • 4 二叉树转换成森林
      • 6.5.3 树和森林的遍历
        • 1. 树的遍历
        • 2. 森林的遍历
    • 6.6 赫夫曼树及其应用
      • 6.6.1 最优二叉树(Huffman树)
        • 1 基本概念
        • 2 Huffman树的构造
      • 6.6.2 赫夫曼编码及其算法
        • 1. Huffman编码
        • 2. Huffman编码算法实现

6.5 树与森林

本节将讨论树的存储结构、树及森林与二叉树之间的相互转换、树的遍历等。

6.5.1 树的存储结构

树的存储结构根据应用的不同而不同。

1. 双亲表示法(顺序存储结构)

#define MAX_SIZE 100
typedef struct PTNode
{
    ElemType data;
    int parent;
} PTNode;

根据该数据结构的定义,PTNode 是 “Parent Tree Node” 的缩写,即“双亲树节点”。在双亲树中,每个节点在存储自己的数据的同时,也存储了其父节点在数组中的位置。

typedef struct
{
    PTNode Nodes[MAX_SIZE];
    int root; /*  根结点位置  */
    int num;  /*  结点数   */
} Ptree;

图6-13所示是一棵树及其双亲表示的存储结构。这种存储结构利用了任一结点的父结点唯一的性质。可以方便地直接找到任一结点的父结点,但求结点的子结点时需要扫描整个数组。

在这里插入图片描述

2 孩子链表表示法

树中每个结点有多个指针域,每个指针指向其一棵子树的根结点。其实这么说有点绕口,其实就是每个指针指向

(1) 定长结点结构

指针域的数目就是树的

其特点是:链表结构简单,但指针域的浪费明显。结点结构如图6-14(a) 所示。在一棵有 n n n 个结点,度为 k k k 的树中必有 n ( k − 1 ) + 1 n(k-1)+1 n(k1)+1 空指针域。

(2) 不定长结点结构

树中每个结点的指针域数量不同,是该结点的度,如图6-14(b) 所示。没有多余的指针域,但操作不便。
在这里插入图片描述

(3) 复合链表结构

n n n 个结点的树有 n n n 个单链表(叶子结点的孩子链表为空),而 n n n 个头结点又组成一个线性表且以顺序存储结构表示。

在这里插入图片描述

#define MAX_NODE 100
typedef struct listnode
{
    int childno; /*  孩子结点编号  */
    struct listno *next;
} CTNode; /*  表结点结构  */

typedef struct
{
    ElemType data;
    CTNode *firstchild;
} HNode; /*  头结点结构  */

typedef struct
{
    HNode nodes[MAX_NODE];
    int root; /*  根结点位置  */
    int num;  /*  结点数   */
} CLinkList;  /*  头结点结构  */

CTNode 是 “Child Next Node” 的缩写
CLinkList 是 “Child Linked List” 的缩写,即“孩子链表”。它是一种树的链式存储结构

在这里插入图片描述

图6-13所示的树T的孩子链表表示的存储结构如图6-16所示。

(考试可能会考,给同学们一棵树,画出若干种表示方法)

3 孩子兄弟表示法(二叉树表示法)

(最重要的表示方法,考试常考)

以二叉链表作为树的存储结构,其结点形式如图6-17(a)所示。

在这里插入图片描述

两个指针域:分别指向结点的第一个子结点和下一个兄弟结点。结点类型定义如下:

typedef struct CSnode
{
    ElemType data;
    struct CSnode *firstchild, *nextsibing;
} CSNode;

CSNode 是 “Child Sibling Node” 的缩写,即“孩子-兄弟节点” 。在以孩子-兄弟表示法存储树或森林时,每个节点包含一个指向它的第一个孩子节点和下一个兄弟节点的指针,称为孩子-兄弟节点。

6.5.2 森林与二叉树的转换

由于二叉树和树都可用二叉链表作为存储结构,对比各自的结点结构可以看出,以二叉链表作为媒介可以导出树和二叉树之间的一个对应关系。

◆ 从物理结构来看,树和二叉树的二叉链表是相同的,只是对指针的逻辑解释不同而已。
◆ 从树的二叉链表表示的定义可知,任何一棵和树对应的二叉树,其右子树一定为空。

图6-18直观地展示了树和二叉树之间的对应关系。

在这里插入图片描述

1 树转换成二叉树

对于一般的树,可以方便地转换成一棵唯一的二叉树与之对应。将树转换成二叉树在“孩子兄弟表示法”中已给出,其详细步骤是:

  • 加虚线。在树的每层按从“左至右”的顺序在兄弟结点之间加虚线相连。
  • 去连线。除最左的第一个子结点外,父结点与所有其它子结点的连线都去掉。
  • 旋转。原有的实线左斜。
  • 整型。将旋转后树中的所有虚线改为实线,并向右斜。该转换过程如图6-19所示。

这样转换后的二叉树的特点是:

◆ 二叉树的根结点没有右子树,只有左子树;

◆ 左子结点仍然是原来树中相应结点的左子结点,而所有沿右链往下的右子结点均是原来树中该结点的兄弟结点。

在这里插入图片描述

2 二叉树转换成树

对于一棵转换后的二叉树,如何还原成原来的树? 其步骤是:

  • 加虚线。若某结点 i i i 是其父结点的左子树的根结点,则将该结点 i i i 的右子结点以及沿右子链不断地搜索所有的右子结点,将所有这些右子结点与 i i i 结点的父结点之间加虚线相连,如图6-20(a)所示。

  • 去连线。去掉二叉树中所有父结点与其右子结点之间的连线,如图6-20(b)所示。

  • 整型。将图中各结点按层次排列且将所有的虚线变成实线,如图6-20(c)所示。

在这里插入图片描述

3 森林转换成二叉树

当一般的树转换成二叉树后,二叉树根节点的右子树必为空。若把森林中的第二棵树(转换成二叉树后)的根结点作为第一棵树(二叉树)的根结点的兄弟结点,则可导出森林转换成二叉树的转换算法如下。

F = { T 1 , T 2 , ⋯ , T n } F=\{T_1, T_2,⋯,T_n\} F={T1,T2,,Tn} 是森林,则按以下规则可转换成一棵二叉树 B = ( root ⁡ , LB ⁡ , RB ⁡ ) B=(\operatorname{root},\operatorname{LB},\operatorname{RB}) B=(rootLBRB)

① 若 $F=\varnothing $,则 B B B 为空树
② 若 F F F 非空,即 n ≠ 0 n\ne 0 n=0,则 B B B 的根 r o o t root root 即为森林中第一棵树的根 r o o t ( T 1 ) root(T_1) root(T1);而其右子树 R B RB RB 是从森林 F ’ = { T 2 , T 3 , ⋯ , T n } F’=\{T_2, T_3,⋯,T_n\} F={T2,T3,,Tn} 转换而成的二叉树。

4 二叉树转换成森林

B = ( r o o t , L B , R B ) B=(root,LB,RB) B=(rootLBRB) 是一棵二叉树,则可以将其转换成由若干棵树构成的森林: F = { T 1 , T 2 , ⋯ , T n } F=\{T_1, T_2,⋯,T_n\} F={T1,T2,,Tn}

转换算法:

① 若 B B B 是空树,则 F F F 为空。
② 若 B B B 非空,则 F F F 中第一棵树 T 1 T_1 T1 的根 r o o t ( T 1 ) root(T_1) root(T1) 就是二叉树的根 r o o t root root T 1 T_1 T1 中根结点的子森林 F 1 F1 F1 是由树 B B B 的左子树 L B LB LB 转换而成的森林; F F F 中除 T 1 T_1 T1 外其余树组成的的森林 F ’ = { T 2 , T 3 , ⋯ , T n } F’=\{T_2, T_3,⋯,T_n\} F={T2,T3,,Tn} 是由 B B B 右子树 R B RB RB 转换得到的森林。

上述转换规则是递归的,可以写出其递归算法。以下给出具体的还原步骤。

6.5.3 树和森林的遍历

1. 树的遍历

由树结构的定义可知,树的遍历有二种方法。

  • 先序遍历:先访问根结点,然后依次先序遍历完每棵子树。如图6-23的树,先序遍历的次序是:
    A B C D E F G I J H K ABCDEFGIJHK ABCDEFGIJHK
  • 后序遍历:先依次后序遍历完每棵子树,然后访问根结点。如图6-23的树,后序遍历的次序是:
    C D B F I J G H E K A CDBFIJGHEKA CDBFIJGHEKA

在这里插入图片描述

说明:
◆ 树的先序遍历实质上与将树转换成二叉树后对二叉树的先序遍历相同。
◆ 树的后序遍历实质上与将树转换成二叉树后对二叉树的中序遍历相同。

对于一般的树而言,并没有明显的左右子树之分,因此在树上定义中序遍历并不合理。对于一般的树,我们主要考虑先遍历根节点还是遍历子树。

其实树的先序遍历实质上与将树转换成二叉树后对二叉树的先序遍历逻辑上是很好理解的,根节点是没有右子树的。那么二叉树实际上逻辑理解就是,先访问根结点,然后访问他的其余子树。对于有右节点的子树的根,根左右可以理解成先访问根,然后访问根下的那棵树,最后再去访问子树森林中的其他树。这样的逻辑结果就和树的遍历中的先序遍历完全一致了。

2. 森林的遍历

F = { T 1 , T 2 , ⋯ , T n } F=\{T_1, T_2,⋯,T_n\} F={T1,T2,,Tn} 是森林,对 F F F 的遍历有二种方法。
⑴ 先序遍历:按先序遍历树的方式依次遍历 F F F 中的每棵树。
⑵ 中序遍历:按中序遍历树的方式依次遍历 F F F 中的每棵树。

6.6 赫夫曼树及其应用

赫夫曼(Huffman)树又称最优树,是一类带权路径长度最短的树,有着广泛的应用。

6.6.1 最优二叉树(Huffman树)

1 基本概念

① 结点路径:从树中一个结点到另一个结点的之间的分支构成这两个结点之间的路径。

② 路径长度:结点路径上的分支数目称为路径长度。

③ 树的路径长度:从树根到每一个结点的路径长度之和。

例图6-23的树。 A A A F F F :结点路径 A E F AEF AEF ;路径长度(即边的数目) 2 2 2 ;树的路径长度: 3 × 1 + 5 × 2 + 2 × 3 = 19 3\times 1+5\times2+2\times3=19 3×1+5×2+2×3=19

在这里插入图片描述

④ 结点的带权路径长度:从该结点的到树的根结点之间的路径长度与结点的权(值)的乘积。

⑤ 树的带权路径长度:树中所有叶子结点的带权路径长度之和,记做:

W P L = w 1 × l 1 + w 2 × l 2 + ⋯ + w n × l n = ∑ w i × l i ( i = 1 , 2 , ⋯   , n ) W P L=w_{1} \times l_{1}+w_{2} \times l_{2}+\cdots+w_{n} \times l_{n}=\sum w_{i} \times l_{i} \quad(i=1,2, \cdots, n) WPL=w1×l1+w2×l2++wn×ln=wi×li(i=1,2,,n)

其中: n n n 为叶子结点的个数; w i w_i wi为第 i i i 个结点的权值; l i l_i li 为第 i i i 个结点的路径长度。

⑥ Huffman树:具有 n n n 个叶子结点(每个结点的权值为 w i w_i wi) 的二叉树不止一棵,但在所有的这些二叉树中,必定存在一棵 W P L WPL WPL 值最小的树,称这棵树为 Huffman 树(或称最优树) 。

在许多判定问题时,利用 Huffman 树可以得到最佳判断算法。如图6-24是权值分别为 2 、 3 、 6 、 7 2、3、6、7 2367,具有 4 4 4 个叶子结点的二叉树,它们的带权路径长度分别为:

( a ) W P L = 2 × 2 + 3 × 2 + 6 × 2 + 7 × 2 = 36 ( b ) W P L = 2 × 1 + 3 × 2 + 6 × 3 + 7 × 3 = 47 ( c ) W P L = 7 × 1 + 6 × 2 + 2 × 3 + 3 × 3 = 34 \begin{aligned} &(a) WPL =2 \times 2+3 \times 2+6 \times 2+7 \times 2=36 \\ &(b) WPL=2 \times 1+3 \times 2+6 \times 3+7 \times 3=47 \\ &(c) W P L=7 \times 1+6 \times 2+2 \times 3+3 \times 3=34 \\ \end{aligned} (a)WPL=2×2+3×2+6×2+7×2=36(b)WPL=2×1+3×2+6×3+7×3=47(c)WPL=7×1+6×2+2×3+3×3=34

其中(c)的 W P L WPL WPL 值最小,可以证明是 Huffman 树。

在这里插入图片描述

2 Huffman树的构造

① 根据 n n n 个权值 { w 1 , w 2 , ⋯ , w n } \{w_1, w_2, ⋯,w_n\} {w1,w2,,wn},构造成 n n n 棵二叉树的集合 F = { T 1 , T 2 , ⋯ , T n } F=\{T_1, T_2, ⋯,T_n\} F={T1,T2,,Tn},其中每棵二叉树只有一个权值为 w i w_i wi 的根结点,没有左、右子树;

② 在 F F F 中选取两棵根结点权值最小的树作为左、右子树构造一棵新的二叉树,且新的二叉树根结点权值为其左、右子树根结点的权值之和;

③ 在 F F F 中删除这两棵树,同时将新得到的树加入F中;

④ 重复②、③,直到F只含一颗树为止。

构造 Huffman 树时,为了规范,规定 F = { T 1 , T 2 , ⋯ , T n } F=\{T_1, T_2, ⋯,T_n\} F={T1,T2,,Tn} 中权值小的二叉树作为新构造的二叉树的左子树,权值大的二叉树作为新构造的二叉树的右子树;在取值相等时,深度小的二叉树作为新构造的二叉树的左子树,深度大的二叉树作为新构造的二叉树的右子树。

图6-25是权值集合 W = { 8 , 3 , 4 , 6 , 5 , 5 } W=\{8, 3, 4, 6, 5, 5\} W={8,3,4,6,5,5} 构造 Huffman 树的过程。所构造的 Huffman 树的 WPL 是:

W P L = 6 × 2 + 3 × 3 + 4 × 3 + 8 × 2 + 5 × 3 + 5 × 3 = 79 \mathrm{WPL}=6 \times 2+3\times 3+4\times 3+8\times 2+5\times 3+5\times 3 =79 WPL=6×2+3×3+4×3+8×2+5×3+5×3=79

6.6.2 赫夫曼编码及其算法

课本P147页

1. Huffman编码

在电报收发等数据通讯中,常需要将传送的文字转换成由二进制字符0、1组成的字符串来传输。为了使收发的速度提高,就要求电文编码要尽可能地短 。此外,要设计长短不等的编码,还必须保证任意字符的编码都不是另一个字符编码的前缀 ,这种编码称为前缀编码。

Huffman树可以用来构造编码长度不等且译码不产生二义性的编码。

设电文中的字符集 C = { c 1 , c 2 , ⋯ , c i , ⋯ , c n } C=\{c_1,c_2, ⋯,c_i, ⋯,c_n\} C={c1,c2,,ci,,cn},各个字符出现的次数或频度集 W = { w 1 , w 2 , ⋯ , w i , ⋯ , w n } W=\{w_1,w_2, ⋯,w_i, ⋯,w_n\} W={w1,w2,,wi,,wn}

从根结点到每个叶子结点所经历的路径分支上的“0”或“1”所组成的字符串,为该结点所对应的编码,称之为 Huffman 编码。

若字符集 C = { a , b , c , d , e , f } C=\{a, b, c, d, e, f\} C={a,b,c,d,e,f} 所对应的权值集合为 W = { 8 , 3 , 4 , 6 , 5 , 5 } W=\{8, 3, 4, 6, 5, 5\} W={8,3,4,6,5,5},如图6-25所示,则字符 a , b , c , d , e , f a,b, c,d, e,f a,b,c,d,e,f 所对应的 Huffman 编码分别是: 10 , 010 , 011 , 00 , 110 , 111 10,010,011,00 ,110,111 1001001100110111

在这里插入图片描述

2. Huffman编码算法实现

(1) 数据结构设计

Huffman 树中没有度为 1 的结点。若有 n n n 个叶子结点的 Huffman 树共有 2 n − 1 2n-1 2n1 个结点,则可存储在大小为 2 n − 1 2n-1 2n1 的一维数组中。实现编码的结点结构如图6-26所示。

在这里插入图片描述

#define MAX_NODE 200 /*   Max_Node>2n-1  */
typedef struct
{
    unsigned int Weight; /*  权值域  */
    unsinged int Parent, Lchild, Rchild;
} HTNode,*HuffmanTree;//动态分配数组存储H树

typedef char **HuffmanCode;//动态分配数组存储

(2) Huffman树的生成

算法实现

void Create_Huffman(unsigned n, HuffmanTree &HT[])
/*  创建一棵叶子结点数为n的Huffman树  */
{
    unsigned int w;m=2*n;
    int k, j;
    for (k = 1; k < m; k++)
    {
        if (k <= n)
        {  
            printf(“\n Please Input Weight : w=?);
            scanf(% d”, &w);
            HT[k].weight = w;
        } /*  输入时,所有叶子结点都有权值  */
        else
            HT[k].weight = 0; /*  非叶子结点没有权值 */
        HT[k].Parent = HT[k].Lchild = HT[k].Rchild = 0;
    } /* 初始化Huffman树 HT */


    for (k = n + 1; k < m; k++)
    {
        unsigned int w1 = 32767, w2 = w1;
        /*  w1 , w2分别保存权值最小的两个权值  */
        int p1 = 0, p2 = 0;
        /*  p1 , p2保存两个最小权值的下标  */
        for (j = 1; j <= k - 1; j++)
        {
            if (HT[j].Parent == 0) /* 尚未合并 */
            {
                /*默认w1是最小的权值*/
                if (HT[j].Weight < w1)
                {
                    w2 = w1;
                    p2 = p1;
                    w1 = HT[j].Weight;
                    p1 = j;
                }
                else if (HT[j].Weight < w2)
                {
                    w2 = HT[j].Weight;
                    p2 = j;
                }
            } /*  找到权值最小的两个值及其下标  */
        }
        HT[k].Lchild = p1;
        HT[k].Rchild = p2;
        HT[k].weight = w1 + w2;
        HT[p1].Parent = k;
        HT[p2].Parent = k;
    }
}

说明:生成 Huffman 树后,树的根结点的下标是 2 n − 1 2n-1 2n1,即 m − 1 m-1 m1

(3) Huffman编码算法

根据出现频度(权值) Weight,对叶子结点的Huffman 编码有两种方式:
① 从叶子结点到根逆向处理,求得每个叶子结点对应字符的 Huffman 编码。
② 从根结点开始遍历整棵二叉树,求得每个叶子结点对应字符的 Huffman 编码。

算法实现

void Huff_coding(unsigned n, Hnode HT[],Huffmancode &HC)
/*  m应为n+1,编码的最大长度n加1 */
{
    int k, sp, fp, m = n + 1;
    char *cd, *HC[m];
    cd = (char *)malloc(n * sizeof(char)); /*  动态分配求编码的工作空间  */

    cd[n] =‘\0; /*  编码的结束标志,不加容易出乱码 */

    for (k = 1; k < n + 1; k++) /*  逐个求字符的编码 */
    {
        sp = n;

        for (p = k, fp = HT[k].parent; fp != 0; p = fp, fp = HT[p].parent)/* 在一次循环中,fp指向的是父结点,p 指向的是当前结点*/
            /*   从叶子结点到根逆向求编码  */
            if (HT[fp].parent == p)
                cd[--sp] =0;
            else
                cd[--sp] =1;
        HC[k] = (char *)malloc((n - sp) * sizeof(char));
        /*  为第k个字符分配保存编码的空间 */
        trcpy(HC[k], &cd[sp]);
    }
    free(cd);
}

课本P154例子非常重要。

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

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

相关文章

数据库篇:表设计、创建编辑以及导出导入数据

微信小程序云开发实战-答题积分赛小程序系列 数据库篇:表设计、添加编辑以及导出导入数据 原型: 最终实现界面截图:

Moqui REST API的两种实现方法

实现Restful API的方法 实现REST API有两种方法。第一种&#xff1a; The main tool for building a REST API based on internal services and entity operations is to define resource paths in a Service REST API XML file such as the moqui.rest.xml file in moqui-fr…

chatGPT国内可用镜像源地址

chatGPT国内可用镜像源地址 彷丶徨丶 关注 IP属地: 湖北 0.811 2023.03.15 16:02:16 字数 1,152 阅读 249,582 如果你正在尝试访问Chatgpt网站&#xff0c;但由于某些原因无法访问该网站&#xff0c;那么你可以尝试使用Chatgpt的国内镜像网站。以下是一些Chatgpt国内镜像网站的…

java基础知识——27.动态代理

这篇文章&#xff0c;我们来学一下java的动态代理 目录 1.动态代理的介绍 2.具体的代码实现 1.动态代理的介绍 动态代理&#xff1a;无侵入式的额外给代码增加功能 很不好理解&#xff0c;下面&#xff0c;我们通过两个例子来说明一下什么是动态代理&#xff1a; 例一&a…

shell编程 -- 基础

shell是一个命令行解释器&#xff0c;它接收应用程序/用户命令&#xff0c;然后调用操作系统内核。 linux笔记 链接&#xff1a;https://pan.baidu.com/s/16GZCPfUTRzUqIyGnYwPuUg?pwds5xt 提取码&#xff1a;s5xt 脚本执行 采用bash或者sh脚本的相对路径或绝对路径&#x…

TikTok跨境电商如何选品和营销?

鑫优尚电子商务&#xff1a;TikTok目前发展飞速&#xff0c;全球的MAU是5.6亿。现在作为全球炙手可热的短视频平台&#xff0c;全球流量相当庞大&#xff0c;覆盖75个语种、全球150个国家和地区。 对于从事跨境电商行业的人来说&#xff0c;又怎能错过一个流量这么好的平台呢&a…

ChatGPT注册详细步骤教程-ChatGPT申请教程

注册chatGPT账号的详细经验教程 注册ChatGPT账号是使用这一自然语言生成技术的关键步骤。下面是注册ChatGPT账号的详细经验教程&#xff1a; 访问OpenAI注册页面 在Web浏览器中打开OpenAI注册页面。 2.输入个人信息 在注册页面上&#xff0c;您需要提供以下个人信息&#…

树莓派 二维云台调零控制

目录 舵机的工作原理 案例程序 要求&#xff1a; 程序&#xff1a; 二维云台是通过IIC总线进行控制的&#xff0c;我们可以通过窗口命令输入&#xff1a;i2cdetect -y 1来检测IIC总线是否连接正常。 当有40显示的时候就说明IIC总线正常。 操控舵机我们需要一个PCA9685的模…

【移动端网页布局】流式布局案例 ④ ( Banner 栏制作 | 固定定位 | 标准流 | 百分比宽度设置 )

文章目录 一、Banner 栏样式及核心要点1、实现效果2、核心要点分析 二、完整代码示例1、HTML 标签结构2、CSS 样式3、展示效果 一、Banner 栏样式及核心要点 1、实现效果 在上一篇博客中 , 实现了 搜索栏 , 在本篇博客开始实现 搜索栏 下方的 Banner 栏 ; 2、核心要点分析 Bann…

OpenCV实战(21)——基于随机样本一致匹配图像

OpenCV实战&#xff08;21&#xff09;——基于随机样本一致匹配图像 0. 前言1. 基于随机样本一致匹配图像1.1 计算基本矩阵与匹配集1.2 随机样本一致算法 2. 算法优化2.1 优化基本矩阵2.2 优化匹配集 3. 完整代码小结系列链接 0. 前言 当两台摄像机拍摄同一场景时&#xff0c…

【Vue面试题】Vue2.x生命周期?

文章目录 1.有哪些生命周期&#xff08;系统自带&#xff09;?beforeCreate( 创建前 )created ( 创建后&#xff09;beforeMount (挂载前)mount (挂载后)beforeUpdate (更新前)updated (更新后)beforeDestroy&#xff08;销毁前&#xff09;destroy&#xff08;销毁后&#xf…

突发:深度学习之父Hinton为了警告AI的风险,不惜从谷歌离职!

‍数据智能产业创新服务媒体 ——聚焦数智 改变商业 今天&#xff0c;AI领域发生了一件标志性事件。那就是Hinton 为了能更自由的表达对AI失控的担忧&#xff0c;不惜从工作了10年的谷歌离职&#xff0c;可见他真的深切的感受到了危机。 不久前&#xff0c;纽约时报的一篇采访…

干货! ICLR:将语言模型绑定到符号语言中个人信息

点击蓝字 关注我们 AI TIME欢迎每一位AI爱好者的加入&#xff01; ╱ 作者简介╱ 承洲骏 上海交通大学硕士生&#xff0c;研究方向为代码生成&#xff0c;目前在香港大学余涛老师的实验室担任研究助理。 个人主页&#xff1a;http://blankcheng.github.io 谢天宝 香港大学一年级…

武忠祥老师每日一题||不定积分基础训练(六)

解法一&#xff1a; 求出 f ( x ) , 进而对 f ( x ) 进行积分。 求出f(x),进而对f(x)进行积分。 求出f(x),进而对f(x)进行积分。 令 ln ⁡ x t , 原式 f ( t ) ln ⁡ ( 1 e t ) e t 令\ln xt,原式f(t)\frac{\ln (1e^t)}{e^t} 令lnxt,原式f(t)etln(1et)​ 则 ∫ f ( x ) d…

分布式配置中心Apollo教程

分布式配置中心Apollo教程 简介 Apollo配置中心课程是传智燕青老师针对微服务开发设计的系列课程之一&#xff0c;本课程讲解了Apollo分布式系统配置中心的使用方法和工作原理&#xff0c;并从实战出发讲解生产环境下的配置中心的构建方案&#xff0c;从Apollo的应用、原理、项…

transformer and DETR

RNN 很难并行化处理 Transformer 1、Input向量x1-x4分别乘上矩阵W得到embedding向量a1-a4。 2、向量a1-a4分别乘上Wq、Wk、Wv得到不同的qi、ki、vi&#xff08;i{1,2,3,4}&#xff09;。 3、使用q1对每个k&#xff08;ki&#xff09;做attention得到a1,i&#xff08;i{1,2,3,4…

STL容器类

STL 1. STL初识 1.1 迭代器 1.1.1 原生指针也是迭代器 #define _CRT_SECURE_NO_WARNINGS #include<iostream> using namespace std; void test01() {int arr[5] { 1,2,3,4,5 };int* p arr;for (int i 0; i < 5; i) {cout << arr[i] << endl;cout &…

在c++项目中使用rapidjson(有具体的步骤,十分详细) windows10系统

具体的步骤&#xff1a; 先下载rapidjson的依赖包 方式1&#xff1a;直接使用git去下载 地址&#xff1a;git clone https://github.com/miloyip/rapidjson.git 方式2&#xff1a;下载我上传的依赖包 将依赖包引入到项目中 1 将解压后的文件放在你c项目中 2 将rapidjson文…

Python小姿势 - # Python中的模板语言

Python中的模板语言 Python是一门非常灵活的语言&#xff0c;其中一个体现就是它可以使用模板语言来生成静态文件。模板语言是一种特殊的语言&#xff0c;用来将静态文本和动态数据结合起来生成新的文本。 Python的模板语言最早出现在Web应用开发中&#xff0c;用来生成HTML页面…

最新版升级GPT4-PLUS攻略

前置条件: 有一个gpt的免费账号 一个魔法上网工具(主要是azure国内版不能用) 1.如果你没有gpt账号&#xff0c;你可以用谷歌邮箱(可以用国内手机号注册)去openai.com官网注册&#xff0c;会卡在手机号那里&#xff0c;这个网上有相关服务&#xff0c;tb也行&#xff0c;反正你…