信息学奥赛初赛天天练-23-CSP-J2023基础题-指针、链表、哈夫曼树与哈夫曼编码的实战应用与技巧大揭秘

news2024/11/27 12:34:32

PDF文档公众号回复关键字:20240608

在这里插入图片描述

单项选择题(共15题,每题2分,共计30分:每题有且仅有一个正确选项)

4 假设有一个链表的节点定义如下:

struct Node {
    int data;    
    Node* next;
};

现在有一个指向链表头部的指针:Node* head。如果想要在链表中插入一个新节点,其成员data的值为42,并使新节点成为链表的第一个节点,下面哪个操作是正确的?( )

A Node* newNode = new Node; newNode->data = 42; newNode->next = head; head = newNode;

B Node* newNode = new Node; head->data = 42; newNode->next = head; head = newNode;

C Node* newNode = new Node; newNode->data = 42; head->next = newNode;

D Node* newNode = new Node; newNode->data = 42; newNode->next = head;

10 假设有一组字符{a,b,c,d,e,f},对应的频率分别为5%,9%,12%,13%,16%,45%。请问以下哪个选项是字符a,b,c,d,e,f分别对应的一组哈夫曼编码?( )

A 1111,1110,101,100,110,0

B 1010,1001,1000,011,010,00

C 000,001,010,011,10,11

D 1010,1011,110,111,00,01

2 相关知识点

1 指针

指针是 C++语言中广泛使用的一种数据类型,运用指针编程是 C++语言最主要的风格之一

指针是一个变量,其值为另一个变量的地址,即,内存位置的直接地址

基础数据类型指针

#include <iostream>
using namespace std;
int main (){
   int  a = 20;   // 实际变量的声明
   int  *ip;      // 指针变量的声明
   ip = &a;       // 在指针变量中存储 a 的地址
   cout << "指针对应变量的值: ";
   cout << a << endl;
   // 输出在指针变量中存储的地址
   cout << "指针变量的值,指针指向的变量的地址: ";
   cout << ip << endl;
   // 访问指针中地址的值
   cout << "指针指向地址对应变量的值(a的值): ";
   cout << *ip << endl;
   return 0;
}

结构体指针

#include<bits/stdc++.h>
using namespace std;
/*
  定义一个结构体,包括姓名和年龄 
*/
struct student{
	string name;
	int age;
}; 
int main(){
	student stu1;//声明 student stu1
	stu1.name="张三";// 张三赋值 name
	stu1.age=21;// 21赋值 age
	student *p1=&stu1;//声明指针p1 指向 &stu1
	//指针去结构体内成员需要用 -> 
	cout<<"姓名:"<<p1->name<<",年龄:"<<p1->age; 
	return 0;
}

2) 链表的插入

指针指向地址的变换

在newNode1前插入newNode2

/*
  1 刚开始head指针指向newNode1
  2 需要newNode2的next指向newNode1
  3 head指向newNode2
*/
#include<bits/stdc++.h>
using namespace std;

struct Node{
	int No;
	Node* next;
}; 

int main(){
	Node* newNode1=new Node;//newNode1 地址0xbe3ea0 指向 No=1变量 
	newNode1->No=1;
	Node* head=newNode1;//指针head 指向 newNode1地址0xbe3ea0
	
	Node* newNode2=new Node;//newNode2 地址0xbe3ee0 指向 No=2变量 
	newNode2->No=2;
	newNode2->next=head;//newNode2->next 指针指向指针head对应地址0xbe3ea0 
	
	head=newNode2;//指针head指向 0xbe3ee0
	
	cout<<head->No<<" "<<head->next->No;
	
	return 0;
}

创建newNode1

Node* newNode1=new Node;//newNode1 地址0xbe3ea0 指向 No=1变量 C++
newNode1->No=1;

head指针指向newNode1

Node* head=newNode1;//指针head 指向 newNode1地址0xbe3ea0

创建newNode2

Node* newNode2=new Node;//newNode2 地址0xbe3ee0 指向 No=2变量 
newNode2->No=2;

newNode2的next指向head指针对应地址

newNode2->next=head;//newNode2->next 指针指向指针head对应地址0xbe3ea0 

head指针指向newNode2

head=newNode2;//指针head指向 0xbe3ee0

上述操作在头指针head后和newNode1之间插入了newNode2

3) 哈夫曼编码

哈夫曼树

哈夫曼树是带权路径长度WPL最短的二叉树(最优二叉树)

构造哈夫曼树的WPL为35是最小的

哈夫曼树的构造

1 选剩下的两棵根权值最小的树合并成一棵新树

2 新树的根权值等于两棵合并前树的根权值和

3 重复1和2

例题

4个点,a、b、c、d,权值分别为7、5、2、4

选根权值最小的两棵树2(c)和4(d)合并,新树的根节点为6

选根权值最小的两棵树5(b)和6合并,新树的根节点为11

选根权值最小的两棵树7(a)和11合并,新树的根节点为18

哈夫曼编码

对哈夫曼树的左右孩子进行编码称为哈夫曼编码,通常左边为0,右边为1

例题

有5个字母E,M,C,A,D

这5个字母的使用频度分别为{E,M,C,A,D}={1,2,3,3,4}

分析

构造哈夫曼树,并进行编码

用频度为权值生成哈夫曼树,并在叶子上标注对应的字母,在树枝上标注分配码“0”或“1”

对应字母的哈夫曼是编码从根节点开始,每条路径到达叶子结点的01代码排列起来

对应的哈夫曼编码

E:000

M:001

C:01

A:10

D:11

哈夫曼编码性质

只对叶子节点进行编码/解码,编码唯一

哈夫曼编码是前缀编码,任何一个字符的编码都不是另一个字符编码的前缀(只有叶子节点编码)

哈夫曼编码左边为0,右边为1是通常规定,也可以左边为1右边为0,但确定后编码是唯一的

3 思路分析

4 假设有一个链表的节点定义如下:

struct Node {
    int data;    
    Node* next;
};

现在有一个指向链表头部的指针:Node* head。如果想要在链表中插入一个新节点,其成员data的值为42,并使新节点成为链表的第一个节点,下面哪个操作是正确的?( )

A Node* newNode = new Node; newNode->data = 42; newNode->next = head; head = newNode;

B Node* newNode = new Node; head->data = 42; newNode->next = head; head = newNode;

C Node* newNode = new Node; newNode->data = 42; head->next = newNode;

D Node* newNode = new Node; newNode->data = 42; newNode->next = head;

答案 A

插入一个新节点

A

假设head开始指向tmp节点,具体需要如下步骤
//1 创建一个Node节点指针 newNode
 Node* newNode = new Node;
//2 通过newNode指针给newNode成员data 赋值为42
newNode->data = 42;
//3 通过newNode指针给newNode成员next 赋值为head指针地址,指向head后续节点tmp
newNode->next = head;
//4 步骤3中新节点已经指向head后续节点tmp,head指向newcode完成插入tmp前
head = newNode;

B

head->data = 42;//和要求不符,要求是对插入节点的data为42

C

 //假设head开始指向tmp节点,缺少下面为新节点指向下个节点,tmp被从链表中剔除
 newNode->next = head;

D

//新节点没有插入到链表中,需要加入如下语句
head = newNode;

10 假设有一组字符{a,b,c,d,e,f},对应的频率分别为5%,9%,12%,13%,16%,45%。请问以下哪个选项是字符a,b,c,d,e,f分别对应的一组哈夫曼编码?( )

A 1111,1110,101,100,110,0

B 1010,1001,1000,011,010,00

C 000,001,010,011,10,11

D 1010,1011,110,111,00,01

答案 A

根据出现的频率对a,b,c,d,e,f构造一棵哈夫曼树

1 频率最小的a和b合并构造1个节点 5+9=14

2 剩下频率最小的2个字符,c和d合并构造1个节点,12+13=25

3 剩下频率最小的2个字符,14和e(16)合并构造1个节点14+16=30

4 剩下频率最小的2个字符,25和30合并构造1个节点,25+30=55

5 剩下频率最小的2个字符,f(45)和55合并构造一个节点45+55=100

对哈夫曼数进行编码

通常对哈夫曼数上的边左边为0,右边为1进行编码,编码后如下图所示

根据上图哈夫曼编码对选项进行分析

有1个1位的哈夫曼编码,选项中只有A有1个1位的哈夫曼编码,其余都没用1位的哈夫曼编码

核对一下A是否正确

A选项abcdef
1111,1110,101,100,110,0
构造哈夫曼树的abcdef
1100,1101,100,101,111,0
由于左右边规定的0和1是可交换的
我们发现c和d最后1位是相反,所以c和d对应边交换一下即可
e也是最后1为是相反的,并且a和b的倒数第2位也都需要交换,所以14和e对应边也可以交换一下
a和b最后1位也都是相反的,所以a和b对应边也可以交换一下

上述操作后对应下图

对应abcdef的哈夫曼树

构造哈夫曼树的abcdef
1111,1110,101,100,110,0
和选项A一致
A选项abcdef
1111,1110,101,100,110,0

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

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

相关文章

【深度学习】CICIDS 2019,入侵检测,SVM支持向量机,随机森林,DNN训练,混淆矩阵

文章目录 数据集介绍Python环境随机森林训练结果SVM支持向量机训练结果DNN训练结果所有代码下载 数据集介绍 下载&#xff1a;https://www.kaggle.com/datasets/tarundhamor/cicids-2019-dataset 数据个数&#xff1a; # 删除label中是WebDDoS的数据df df[df[Label] ! WebDD…

Java Web学习笔记26——Element常用组件

常见组件&#xff1a; 就是一个复制和粘贴的过程。 Table表格&#xff1a;用于展示多条结构类的数据&#xff0c;可对数据进行排序、筛选、对比或其他自定义操作。 常见组件-分页主键&#xff1a; Pagination&#xff1a;分页&#xff1a;当数据量比较多时&#xff0c;使用分…

第七届全国颗粒材料计算力学会议召开,DEMms多尺度离散模拟软件受关注

近日&#xff0c;第七届全国颗粒材料计算力学会议暨第四届计算颗粒技术国际研讨会在南京召开。会议聚焦颗粒材料的力学理论及模型、计算分析与软件开发、工程应用和相关前沿方向中的关键科学问题和难点技术问题&#xff0c;开展广泛的学术交流和讨论。 会议期间&#xff0c;积鼎…

【Python列表解锁】:掌握序列精髓,驾驭动态数据集合

文章目录 &#x1f680;一、列表&#x1f308;二、常规操作&#x1f4a5;增&#x1f4a5;删&#x1f4a5;改&#x1f4a5;查 ⭐三、补充操作 &#x1f680;一、列表 列表是一个能够存储多个同一或不同元素的序列 列表&#xff1a;list ---- [] 列表属于序列类型&#xff08;容器…

WWDC 2024前瞻:苹果如何用AI技术重塑iOS 18和Siri

苹果下周的全球开发者大会有望成为这家 iPhone 制造商历史上的关键时刻。在 WWDC 上&#xff0c;这家库比蒂诺科技巨头将展示如何选择将人工智能技术集成到其设备和软件中&#xff0c;包括通过与 OpenAI 的历史性合作伙伴关系。随着重大事件的临近&#xff0c;有关 iOS 18 及其…

高能来袭|联想拯救者携手《黑神话:悟空》玩转东方神话世界

从2020年首次发布实机演示视频以来&#xff0c;《黑神话&#xff1a;悟空》便在全球范围内获得了广泛关注&#xff0c;成为国产3A游戏的现象级爆款。6月&#xff0c;联想拯救者正式宣布成为《黑神话&#xff1a;悟空》全球官方合作伙伴&#xff0c;致力于共同革新国产游戏体验&…

老师必备!一文教你如何高效收集志愿填报信息

高考志愿填报季&#xff0c;对于每一位老师来说&#xff0c;无疑是一场信息收集与管理的硬仗。如何在众多的志愿信息中&#xff0c;高效、准确地掌握每位学生的志愿意向&#xff1f; 高考志愿填报的重要性。不仅是学生人生的一个重要转折点&#xff0c;也是老师教育生涯中的一次…

Elasticsearch 认证模拟题 - 15

一、题目 原索引 task1 的字段 title 字段包含单词 The&#xff0c;查询 the 可以查出 1200 篇文档。重建 task1 索引为 task1_new&#xff0c;重建后的索引&#xff0c; title 字段查询 the 单词&#xff0c;不能匹配到任何文档。 PUT task1 {"mappings": {"…

Latex中表格(3)

Latex中的表格 一、多行或多列单元格 这篇主要说Latex中表格出现多行或者多列单元格的形式. 一、多行或多列单元格 可能用到的宏包 \usepackage{booktabs}\usepackage{multirow} 代码&#xff1a; \begin{table}[h!] \centering \caption{Your caption here} \begin{tabul…

斯坦福天才少女创5亿独角兽!Pika获8000万融资,金牌团队首曝光

斯坦福天才少女创立的公司Pika&#xff0c;继续书写传奇。 GPT-4o深夜发布&#xff01;Plus免费可用&#xff01;https://www.zhihu.com/pin/1773645611381747712 没体验过OpenAI最新版GPT-4o&#xff1f;快戳最详细升级教程&#xff0c;几分钟搞定&#xff1a;升级ChatGPT-4o …

地图之战争迷雾/地图算法/自动导航(一)

战争迷雾 TiledMap 创建黑色覆盖块&#xff0c;然后使用碰撞组件&#xff0c;控制黑色块的显示和隐藏 地图算法 在有些游戏中&#xff0c;地图需要随机生成&#xff0c;比如游戏中的迷宫等&#xff0c;这就需要地图生成的算法&#xff1b;在角色扮演类游戏中&#xff0c;角色…

【AIGC】基于大模型+知识库的Code Review实践

一、背景描述 一句话介绍就是&#xff1a;基于开源大模型 知识库的 Code Review 实践&#xff0c;类似一个代码评审助手&#xff08;CR Copilot&#xff09;。信息安全合规问题&#xff1a;公司内代码直接调 ChatGPT / Claude 会有安全/合规问题&#xff0c;为了使用 ChatGPT…

华为云服务器-云容器引擎 CCE环境构建及项目部署

1、切换地区 2、搜索云容器引擎 CCE 3、购买集群 4、创建容器节点 通过漫长的等待(五分钟左右)&#xff0c;由创建中变为运行中&#xff0c;则表明容器已经搭建成功 购买成功后&#xff0c;返回容器控制台界面 5、节点容器管理 6、创建redis工作负载 7、创建mysql工作负载 8、…

C#使用GDI对一个矩形进行任意角度旋转

C#对一个矩形进行旋转GDI绘图&#xff0c;可以指定任意角度进行旋转 我们可以认为一张图片Image&#xff0c;本质就是一个矩形Rectangle,旋转矩形也就是旋转图片 在画图密封类 System.Drawing.Graphics中&#xff0c; 矩形旋转的两个关键方法 //设置旋转的中心点 public v…

MySQL-相关日志

官方文档 1、MySQL支持的日志 MySQL有不同类型日志文件&#xff0c;用来存储不同类型的日志&#xff0c;分别为 二进制日志、错误日志、通用查询日志、慢查询日志、中继日志、数据定义语句日志 慢查询日志&#xff1a;记录所有执行时间超过 long_query_time的所有查询&#xf…

单元测试覆盖率

什么是单元测试覆盖率 关于其定义&#xff0c;先来看一下维基百科上的一段描述&#xff1a; 代码覆盖&#xff08;Code coverage&#xff09;是软件测试中的一种度量&#xff0c;描述程序中源代码被测试的比例和程度&#xff0c;所得比例称为代码覆盖率。 简单来理解&#xff…

【微信小程序】事件绑定和事件对象

文章目录 1.什么是事件绑定2.button组件3.事件绑定4.input组件 1.什么是事件绑定 小程序中绑定事件与在网页开发中绑定事件几乎一致&#xff0c;只不过在小程序不能通过on的方式绑定事件&#xff0c;也没有click等事件&#xff0c;小程序中 绑定事件使用bind方法&#xff0c;c…

反转链表 (oj题)

一、题目链接 https://leetcode.cn/problems/reverse-linked-list/submissions/538124207 二、题目思路 1.定义三个指针&#xff0c;p1先指向NULL p2指向头结点 p3指向第二个结点 2.p2的next指向p1。然后移动指针&#xff0c;p1来到p2的位置&#xff0c;p2来到p3的位置&…

双列集合基础知识

package exercise;import java.util.HashMap; import java.util.Map;public class Demo1 {public static void main(String[] args) {Map<String, String> map new HashMap<>();//在添加数据的时候&#xff0c;如果键不存在&#xff0c;那么直接把键值对对象添加到…

小主机折腾记25

10.买了惠普光驱&#xff0c;想给880g5twr安装上&#xff0c;结果发现卡扣不对 880g5twr的卡扣更长一些&#xff0c;比光驱本身长一些&#xff0c;各位如果想买的注意擦亮眼睛&#xff0c;看看卡扣跟你的主机一致与否 后续在闲鱼上买了个卡扣&#xff0c;加邮费12块钱…… 1…