当前位置: 首页 > news >正文

给企业做网站多少钱网站建设gxjzdrj

给企业做网站多少钱,网站建设gxjzdrj,炫酷的企业网站,汕头网站模板价格文章目录 一、前言二、堆的基本概念1. 堆的定义2. 堆的存储方式 三、堆的基本操作1. 插入操作#xff08;Insert#xff09;C 实现#xff08;大根堆#xff09; 2. 删除堆顶元素#xff08;Extract Max / Min#xff09;C 实现#xff08;大根堆#xff09; 3. 堆排序… 文章目录 一、前言二、堆的基本概念1. 堆的定义2. 堆的存储方式 三、堆的基本操作1. 插入操作InsertC 实现大根堆 2. 删除堆顶元素Extract Max / MinC 实现大根堆 3. 堆排序Heap SortC 实现 五、堆的应用1. **优先队列**2. **求 Top K 问题**3. **Dijkstra 最短路径算法** 六、总结 一、前言 在数据结构中堆Heap是一种特殊的完全二叉树通常用于实现优先队列Priority Queue。堆分为大根堆Max Heap和小根堆Min Heap分别适用于不同的应用场景例如堆排序、求Top K问题、Dijkstra最短路径算法等。 本文将介绍堆的概念、基本操作、应用以及C和Python的代码实现。 二、堆的基本概念 1. 堆的定义 堆是一种完全二叉树并且满足以下性质 大根堆最大堆 父节点的值总是大于等于子节点的值。小根堆最小堆 父节点的值总是小于等于子节点的值。 完全二叉树如果树的每一层都被完全填满除了可能的最后一层并且最后一层的节点靠左对齐则称其为完全二叉树。 2. 堆的存储方式 堆通常用数组存储父子关系通过索引计算 父节点索引 parent(i) (i - 1) / 2左子节点索引 left(i) 2 * i 1右子节点索引 right(i) 2 * i 2 三、堆的基本操作 1. 插入操作Insert 插入新元素的步骤 将元素放入数组的末尾。进行上浮Heapify-Up操作调整堆结构。 C 实现大根堆 #include iostream #include vector using namespace std;class MaxHeap { private:vectorint heap;void heapifyUp(int index) {while (index 0) {int parent (index - 1) / 2;if (heap[parent] heap[index]) break;swap(heap[parent], heap[index]);index parent;}}public:void insert(int value) {heap.push_back(value);heapifyUp(heap.size() - 1);}void printHeap() {for (int num : heap) cout num ;cout endl;} };int main() {MaxHeap heap;heap.insert(10);heap.insert(20);heap.insert(5);heap.insert(30);heap.printHeap();return 0; }输出示例 30 20 5 102. 删除堆顶元素Extract Max / Min 删除堆顶元素的步骤 将堆顶元素与堆的最后一个元素交换并移除最后一个元素。进行下沉Heapify-Down操作调整堆结构。 C 实现大根堆 void heapifyDown(int index) {int size heap.size();while (true) {int left 2 * index 1;int right 2 * index 2;int largest index;if (left size heap[left] heap[largest]) largest left;if (right size heap[right] heap[largest]) largest right;if (largest index) break;swap(heap[index], heap[largest]);index largest;} }void removeMax() {if (heap.empty()) return;heap[0] heap.back();heap.pop_back();heapifyDown(0); }3. 堆排序Heap Sort 堆排序的基本思想 建堆Heapify将无序数组转换为堆结构。 排序 交换堆顶元素与最后一个元素并移除最后一个元素。重新调整堆结构Heapify-Down。重复此过程直到所有元素有序。 C 实现 void heapSort(vectorint arr) {int n arr.size();// 构建最大堆for (int i n / 2 - 1; i 0; i--) {heapify(arr, n, i);}// 交换并调整堆for (int i n - 1; i 0; i--) {swap(arr[0], arr[i]);heapify(arr, i, 0);} }五、堆的应用 1. 优先队列 堆可以高效地实现优先队列使得插入和取出最大最小值的时间复杂度为O(log N)。 2. 求 Top K 问题 使用大小为 K 的最小堆可以在 O(N log K) 的时间内求出前 K 大的元素。 import heapqdef topK(nums, k):return heapq.nlargest(k, nums) # 取前 K 个最大元素print(topK([3, 1, 5, 12, 2, 11], 3)) # [12, 11, 5]3. Dijkstra 最短路径算法 在图算法中堆被用于优化最短路径算法以高效找到当前最短路径的顶点。 六、总结 堆是完全二叉树常用于实现优先队列。堆的基本操作插入Heapify-Up、删除Heapify-Down、堆排序。堆的应用广泛包括 Top K 问题、Dijkstra 算法等。 堆的高效性使其在数据流处理、搜索优化、任务调度等场景下广泛使用是数据结构中非常重要的一部分。
http://www.hkea.cn/news/14545638/

相关文章:

  • 做学校和企业对接的网站网站开发培训光山
  • 完成网站建设成本泉州建站模板厂家
  • 网站源码 酷wordpress改后台地址
  • 荆州网站建设营销网站制作教程
  • 搜索引擎有哪些网站男人不知本网站 枉做
  • 免费搭建平台网站网页设计实训总结1500字通用
  • 图片无版权网站滨州做网站建设的公司
  • 做网站的系统做网站备案需要多长时间
  • 工程建设网站导航图网站推广如何做的
  • 精品下载站网站开发需要哪些人才
  • 太原建站公司有哪些wordpress表格美化
  • 南宁企业网站建设制作外卖网站设计
  • 江苏省城乡建设部网站首页微信上做网站
  • 界面设计好看的网站php与wordpress
  • dedecms手机网站模板安装教程网站接入银联支付怎么做
  • html 类似淘宝购物网站上加载时获取属性并可多选过滤 代码网页网站设计
  • 社交型网站首页面设计分析创建一个网站的创业计划书
  • 设计公司网站域名有什么做数学题的网站
  • 网页设计视频网站做网站开创和中企动力哪家强
  • 南宁做网站找哪家好青岛网络工程优化
  • 网站建设工作室北京小俊哥甘肃电子商务网站建设
  • 海口高端品牌网站建设wordpress调用友情链接分类
  • 电子商务网站建设习题答案企业网站虚拟空间
  • 设计接活的网站链接地址
  • 吉林市做网站的科技wordpress iis 500.50
  • 网站建设需要怎么选合作机构生鲜网站怎么做
  • 三明交通建设集团网站移动端网站模板怎么做
  • 网站页面设计与实现杭州网站建设浙江
  • 做餐饮的餐具网站有哪些网络营销和网络推广有什么区别
  • 网站网站模板怎么样才能建立网站平台