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

堆堆堆,咕咕咕

1.找TopK问题

要找到最前面的k个元素

void swap(int *a,int *b)
{int temp=*a;*a=*b;*b=temp;
}
//向下调整最小堆
void minheapify(int arr[],int n,int index)
{int left=2*index+1;int right=2*index+2;int smallest=index;if(left<n&&arr[left]<arr[smallest]) smallest=left;if(right<n&&arr[right]<arr[smallest]) smallest=right;if(smallest!=index){swap(&arr[smallest],&arr[index]);minheapify(arr,n,smallest);}
}
//创建最小堆
void buildminheap(int arr[],int n)
{for(int i=(n-2)/2;i>=0;i--){minheapify(arr,n,i);}
}
//寻找顶端
void findtopk(int arr[],int n,int k)
{if(k<=0||k>n){return;}int* heap=(int*)malloc(k*sizeof(int));for(int i=0;i<k;i++){heap[i]=arr[i];}buildheap(arr,k);for(int i=k;i<n;i++){if(arr[i]>heap[0]){heap[0]=arr[i];minheapify(heap,k,0);}for(int i=0;i<k;i++){printf("%d\n",heap[i]);}free(heap);
}

时间复杂度O(n)=k+(n-k)log2 k

2.链式二叉树

typedef int BT
typedef struct BTNode
{
struct BTNode* left;//左孩子
struct BTNdde* right;//右孩子
BT val;
}BTNode;BTNode* BuyBTNode(int val)
{
BTNode* newnode=(BTNode*)malloc(sizeof(BTNode));
if(newnode==NULL)
{
perror("malloc");
return NULL;
}
newnode->val=val;
newnode->left=NULL;
newnode->right=NULL;
return newnode;
}
BTNode* CreateTree()
{
BTNode* n1=BuyBTNode(1);
BTNode* n2=BuyBTNode(2);
BTNode* n3=BuyBTNode(3);
BTNode* n4=BuyBTNode(4);
BTNode* n5=BuyBTNode(5);
BTNode* n6=BuyBTNode(6);
BTNode* n7=BuyBTNode(7);
n1->left=n2;
n1->right=n4;
n2->left=n3;
n4->left=n5;
n4->right=n6;
n5->left=n7;
return n1;
}

前序遍历:访问顺序:根结点,左子树,右子树

中序遍历:访问顺序:左子树,根结点,右子树

后序遍历:访问顺序:左子树,右子树,根结点

void PreOrder(BTNode* root)
{
if(root==NULL)
{
printf("N");
return;
}
printf("%d",root->val);
PreOrder(root->left);
PreOrder(root->right);
}void InOrder(BTNode* root)
{
if(root==NULL)
{
printf("N");
return;
}
InOrder(root->left);
printf("%d",root->val);
InOrder(root->right);
}void PostOrder(BTNode* root)
{
if(root==NULL)
{
printf("N");
return;
}
PostOrder(root->left);
PostOrder(root->right);
printf("%d",root->val);
}

http://www.xdnf.cn/news/15916.html

相关文章:

  • python的多线程无法并行只能并发,why?
  • GA-BP遗传算法优化BP神经网络数据生成,采用SVM分类模型评估
  • roslaunch 文件的核心语法和使用技巧
  • Linux内核设计与实现 - 第5章 系统调用
  • docker构建springboot镜像
  • 数据结构之图
  • 【办公类-107-02】20250719视频MP4转gif(削减MB)
  • MyBatis分页神器PageHelper深度解析
  • 深入解析文件操作(上)- 二进制文件和文本文件,流的概念,文件的打开和关闭
  • 计算机网络1.1:计算机网络在信息时代的作用
  • Redis常见线上问题
  • Javascript进程和线程通信
  • VIT速览
  • Nestjs框架: RxJS 核心方法实践与错误处理详解
  • XSS漏洞----基于Dom的xss
  • 混沌趋势指标原理及交易展示
  • python爬虫之获取渲染代码
  • Python 数据分析模板在工程实践中的问题诊断与系统性解决方案
  • 探索量子计算与法律理论的交叉领域
  • Zephyr环境搭建 - Board GD32A503
  • 力扣 hot100 Day49
  • 数据集下载网站
  • XSS漏洞知识总结
  • [spring6: AspectMetadata AspectInstanceFactory]-源码解析
  • PCIe RAS学习专题(3):AER内核处理流程梳理
  • 消息队列:数字化通信的高效纽带
  • 1009 - 数组逆序
  • Spring监听器
  • 2.4 组件间通信Props(父传子)
  • Rust Web 全栈开发(九):增加教师管理功能