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

做资讯网站需要什么资质企业网站托管

做资讯网站需要什么资质,企业网站托管,cms建站系统是什么,公众号外链网站怎么做超级丑数是一个正整数,并且它的质因数只包含在给定的质数列表中。超级丑数的定义类似于丑数,但可以根据特定需求改变质因数的范围。下面是如何在C语言中实现求解超级丑数的代码。 我们使用最小堆(优先队列)来高效地生成超级丑数序…

超级丑数是一个正整数,并且它的质因数只包含在给定的质数列表中。超级丑数的定义类似于丑数,但可以根据特定需求改变质因数的范围。下面是如何在C语言中实现求解超级丑数的代码。

我们使用最小堆(优先队列)来高效地生成超级丑数序列。优先队列可以帮助我们始终获得当前最小的超级丑数。

代码实现

#include <stdio.h>
#include <stdlib.h>#define MAX_HEAP_SIZE 10000typedef struct {int* data;int size;
} MinHeap;// 创建一个最小堆
MinHeap* createMinHeap() {MinHeap* heap = (MinHeap*)malloc(sizeof(MinHeap));heap->data = (int*)malloc(MAX_HEAP_SIZE * sizeof(int));heap->size = 0;return heap;
}// 向堆中插入元素
void insertMinHeap(MinHeap* heap, int value) {if (heap->size >= MAX_HEAP_SIZE) {printf("Heap overflow!\n");return;}int i = heap->size++;while (i > 0 && heap->data[(i - 1) / 2] > value) {heap->data[i] = heap->data[(i - 1) / 2];i = (i - 1) / 2;}heap->data[i] = value;
}// 删除堆顶元素
int extractMin(MinHeap* heap) {if (heap->size <= 0) {printf("Heap underflow!\n");return -1;}int minValue = heap->data[0];heap->data[0] = heap->data[--heap->size];int i = 0;while (i * 2 + 1 < heap->size) {int j = i * 2 + 1;if (j + 1 < heap->size && heap->data[j + 1] < heap->data[j]) {j++;}if (heap->data[i] <= heap->data[j]) {break;}int temp = heap->data[i];heap->data[i] = heap->data[j];heap->data[j] = temp;i = j;}return minValue;
}// 检查堆中是否包含某个元素
int contains(MinHeap* heap, int value) {for (int i = 0; i < heap->size; i++) {if (heap->data[i] == value) {return 1;}}return 0;
}// 找到第n个超级丑数
int nthSuperUglyNumber(int n, int* primes, int primesSize) {MinHeap* heap = createMinHeap();insertMinHeap(heap, 1);int superUgly = 1;for (int i = 0; i < n; i++) {superUgly = extractMin(heap);for (int j = 0; j < primesSize; j++) {int newUgly = superUgly * primes[j];if (!contains(heap, newUgly)) {insertMinHeap(heap, newUgly);}}}free(heap->data);free(heap);return superUgly;
}int main() {int primes[] = {2, 3, 5};int primesSize = sizeof(primes) / sizeof(primes[0]);int n = 10; // 找到第10个超级丑数int result = nthSuperUglyNumber(n, primes, primesSize);printf("The %d-th super ugly number is: %d\n", n, result);return 0;
}

代码解释

  1. 堆数据结构

    • MinHeap结构体定义了最小堆的数据结构,包括一个动态数组和堆的大小。
    • createMinHeap函数创建并初始化最小堆。
    • insertMinHeap函数插入新元素到最小堆,同时维护堆的性质。
    • extractMin函数从最小堆中提取最小元素,并重新调整堆。
    • contains函数检查堆中是否包含某个元素,防止插入重复元素。
  2. 超级丑数计算

    • nthSuperUglyNumber函数接受要查找的超级丑数的位置n,质因数数组primes及其大小primesSize
    • 函数使用最小堆来依次生成超级丑数。每次从堆中取出最小的超级丑数,然后将其乘以所有质因数生成新的超级丑数并插入堆中。
    • 循环执行上述步骤直到找到第n个超级丑数。
  3. 主函数

    • main函数中定义了质因数数组primes,并调用nthSuperUglyNumber函数找到第n个超级丑数并输出结果。

通过这种方式,我们能够高效地找到指定位置的超级丑数。该算法利用最小堆的数据结构,确保每次都能获得当前最小的超级丑数,并避免生成重复的超级丑数。

http://www.zhongyajixie.com/news/1521.html

相关文章:

  • 美女做美网站网络新闻发布平台
  • 全景网站制作教程福州seo排名公司
  • 政府网站制作方案做了5天游戏推广被抓了
  • 佛山自己网站建设公司网站模板设计
  • 如何做网站超链接网站关键词快速排名工具
  • 渝叶购零售客户电商网站营销网络图
  • 个体户查名字是否被注册班级优化大师怎么用
  • 电子商务网站建设流程新东方教育培训机构
  • 如何快速做h5网站南宁百度推广代理公司
  • 邯郸注册公司搜索引擎优化的目的是
  • 著名室内设计师seo网络优化专员
  • 成都哪个公司做网站爱站长尾词
  • 旅游电子商务的网站建设新闻源软文推广平台
  • 网站显示百度众测是怎么做的网店搜索引擎优化的方法
  • 大宅装修抖音seo推荐算法
  • 论坛备案网站名称东莞市民最新疫情
  • 网站建设具体日程安排广告推广图片
  • 国外免费舆情网站有哪些软件关键词上首页的有效方法
  • 广州网站建设是什么seo快排
  • 厦门网站建设seo百度快照怎么优化排名
  • 做坑网站需要seo网络推广招聘
  • 园林公司做网站的好处枸橼酸西地那非片的功效与作用
  • 一个网址建多个网站网站查询服务器
  • 越秀定制型网站建设找培训机构的网站
  • 建筑设计地图网站广州网站优化运营
  • 贵阳专业做网站的公司有哪些新闻稿撰写
  • a家兽装定制网站重庆百度推广开户
  • 深圳大鹏住房和建设局网站推广营销
  • 网站建设的技术seo网站优化详解
  • 网站跳出率什么意思宁波seo网络推广定制多少钱