第五十九练 插入排序实现

简介: 第五十九练 插入排序实现

第五十九练 插入排序实现

请使用插入排序算法实现一个函数,对整数数组进行降序排序。

要求:

  1. 输入:整数数组和数组长度
  2. 输出:无序数组按降序排列

第五十八练答案

以下是使用堆排序算法实现对整数数组降序排序的C语言程序,包含相应的题解:

#include <stdio.h>

// 函数声明
void heapSortDescending(int arr[], int n);
void buildMaxHeap(int arr[], int n);
void maxHeapify(int arr[], int n, int i);

int main() {
    // 示例用法
    int arr[] = {12, 11, 13, 5, 6, 7};
    int n = sizeof(arr) / sizeof(arr[0]);

    // 调用降序排序函数
    heapSortDescending(arr, n);

    // 输出排序后的数组
    printf("降序排序后的数组:\n");
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }

    return 0;
}

// 堆排序函数(降序)
void heapSortDescending(int arr[], int n) {
    // 构建最大堆
    buildMaxHeap(arr, n);

    // 从最后一个非叶子节点开始,依次将最大元素交换到数组末尾并调整堆
    for (int i = n - 1; i > 0; i--) {
        // 交换当前根节点(最大值)与数组末尾元素
        int temp = arr[0];
        arr[0] = arr[i];
        arr[i] = temp;

        // 调整堆,将剩余元素重新构建成最大堆
        maxHeapify(arr, i, 0);
    }
}

// 构建最大堆
void buildMaxHeap(int arr[], int n) {
    // 从最后一个非叶子节点开始,依次调整堆
    for (int i = n / 2 - 1; i >= 0; i--) {
        maxHeapify(arr, n, i);
    }
}

// 调整堆,保持最大堆性质
void maxHeapify(int arr[], int n, int i) {
    int largest = i;     // 初始化最大值索引为当前节点
    int left = 2 * i + 1; // 左子节点索引
    int right = 2 * i + 2; // 右子节点索引

    // 找到左、右子节点中的最大值索引
    if (left < n && arr[left] > arr[largest]) {
        largest = left;
    }
    if (right < n && arr[right] > arr[largest]) {
        largest = right;
    }

    // 如果最大值索引不是当前节点,交换节点值并递归调整堆
    if (largest != i) {
        int temp = arr[i];
        arr[i] = arr[largest];
        arr[largest] = temp;

        maxHeapify(arr, n, largest);
    }
}

题解:

  • 程序定义了一个名为 heapSortDescending 的函数,以堆排序算法为基础,用于对整数数组进行降序排序。
  • 在主函数中,示例用法包括一个整数数组 arr,然后调用 heapSortDescending 函数进行降序排序。
  • 堆排序算法的主要思想是通过构建最大堆,将最大值(根节点)与数组末尾元素交换,并调整堆,重复这个过程,直到整个数组有序。
  • buildMaxHeap 函数用于构建最大堆,从最后一个非叶子节点开始,依次调整堆。
  • maxHeapify 函数用于调整堆,保持最大堆性质。给定一个节点,比较其与左右子节点的大小,将最大值移到当前节点。
  • 最终,通过调用 heapSortDescending 函数,得到一个降序排序的数组,并输出结果。

答案和解析会在次日公布

注意事项

编写代码的时候,需要注意以下几点问题:

  • 头文件的引用需要放在代码的最顶部
  • 每个C语言程序中必须包含一个 main函数
  • void main(){}
  • int main(){return 0;}
  • C语言中每一行的结尾处必须要使用分号结尾
  • C语言中的引号需要使用双引号,双引号都是以一对一对的情况出现的
  • 在scanf键盘输入代码中,要使用 & 加变量名来读取一个键盘输入
  • 赋值语句是将右边的值赋给左边的变量,顺序不能反了
  • 需要注意代码的缩进格式,缩进为4个空格或者一个tab键为一组,但是要保证整篇代码里面风格一致,要么都是4个空格缩进,要么都是使用一个tab进行缩进
  • 需要养成随手保存的习惯,保存的快捷键一般是 ctrl + s
  • 注意大括号的使用,大括号是代码块,代表了一个块的代码是放在一起的
  • 注意整数型和实数型的转换,如果将实数赋值给一个整形变量,那么实数的小数部分将会被舍去;
  • 注意除法中,如果除数和被除数都是整数,那么结果也会是一个整数,小数部分会自动舍弃
  • 成对出现的标点符号
  • 单引号,双引号,小括号,中括号,大括号等,一般不单独出现
  • 如果代码有问题,然后附近又刚好有这些成对符号,请着重关注
  • 定义变量时,该打的逗号应该打上,不能写掉了
  • 编写++符号时,不要误写成了ff
  • 一个程序里面只能有一个main函数,除了main函数的其他函数都不能叫这个名字
  • 在调用函数时,入参都是使用的逗号隔开,一定不要使用分号隔开
  • 换行符是\n,不能错误写成/n
  • 输入输出格式化
  • %.2f是保留两位小数
  • %d对应整数
  • %c对应字符
  • %f对应实数
  • 不要写错或者写漏了
  • if条件语句当前行不能加分号,不然这个语句就没有意义了
  • while语句和if语句一样,当行不能加分号
  • 不建议使用goto语句,因为那样会造成程序结构的混乱,导致不可读

更多

欢迎来到C语言每日一练服务!

在现代技术的飞速发展中,编程已经成为一项不可或缺的技能。C语言作为一门经典的编程语言,奠定了计算机科学的基石,为学习其他编程语言打下了坚实的基础。为了帮助大家更好地掌握C语言,我们特别推出了每日一练服务,旨在提供系统性、全面性的学习支持。

我们的服务特点包括:

  1. 日常练习题目: 每天我们会提供一道C语言练习题目,涵盖基础知识、算法、数据结构等多个领域。这些题目既有难度,又具有实际应用价值,帮助你锻炼编程技能。
  2. 详细解析: 我们不仅提供每道题的标准答案,还会提供详细的解析和优秀代码示例。通过对解题思路的深入剖析,你能够更好地理解和掌握各种编程技巧。
  3. 互动学习社区: 通过微信文章评论区建立了一个互动学习社区,供学员们交流讨论。你可以在这里提问问题、分享经验,与其他学员一起成长。
  4. 个性化学习建议: 根据你的学习表现,我们会为你推荐相应难度的练习题,确保你的学习过程既具挑战性,又不至于过于困难,保持学习的动力和兴趣。

参与每日一练的好处:

  • 持续学习提升技能: 每日坚持练习,你的编程技能将会得到持续提升,不断进步。
  • 增强自信心: 通过解决各种类型的问题,你将建立起对自己技能的信心,更加轻松应对编程挑战。
  • 拓宽思路: 每道题都是一个小挑战,通过解决这些问题,你将培养出灵活的思维,更好地应对实际编程工作中的挑战。
  • 为未来发展奠定基础: 无论你是初学者还是有一定经验的程序员,C语言每日一练都将为你未来的编程发展奠定坚实的基础。

加入我们的C语言每日一练服务,一起挑战编程难题,不断提升自己,走向编程高手的道路!

目录
打赏
0
1
1
0
47
分享
相关文章
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html><head><meta http-equiv="Cont
region分裂有2种触发情景:1是用户手动触发(参见HRegionServer的splitRegion方法),2是后台flush线程flush完一个region的memstore时,会去检查这个region是否需要分裂(参见MemStoreFlushe的flushRegion方法)。
950 0
专访朱少民:三十年深厚积淀,十年磨剑,经典之作再现测试江湖
十年过去了,软件测试领域发生了很大变化,作者也发生了很大变化。虽然离开了WebEx、Cisco,离开了在企业一线的测试工作,来到了同济大学教书,但我一直没有失去和工业界的联系,而且不再局限一家公司的实践,视野更开阔了。
1790 0
Confluence 6 如何添加用户组图文教程
选择基本配置 选择用户组 在界面中选择添加用户组 输入用户组名字后保存就可以了 https://wiki.ossez.
1380 0
【智力题】有多少残疾士兵?
有100个残疾兵.其中70名失去一只眼,75兵失去一只耳,80名失去一只手,85名失去一只脚。问:同时失去眼,耳,手,脚的兵至少有多少人?(可以有其他种类的残疾)答案:10人。(70+75-100+80-100+85-100)
1016 0
kde
|
16天前
|
Docker镜像加速指南:手把手教你配置国内镜像源
配置国内镜像源可大幅提升 Docker 拉取速度,解决访问 Docker Hub 缓慢问题。本文详解 Linux、Docker Desktop 配置方法,并提供测速对比与常见问题解答,附最新可用镜像源列表,助力高效开发部署。
kde
9765 77
|
13天前
typora免费版,激活方法,Typora使用教程
Typora是一款简洁高效的Markdown编辑器,支持即时渲染。本教程涵盖安装方法、文件操作、视图控制、格式排版、字体样式及Markdown语法,助你快速上手使用Typora进行高效写作。
2466 6
Windows安装Claude Code
Claude Code 是 Anthropic 推出的代码助手,支持在 Windows 通过 WSL(Windows Subsystem for Linux)运行。本文介绍如何在 Windows 系统中启用 WSL、安装 Ubuntu 子系统、配置 Python 与 Node.js 环境,并最终安装和运行 Claude Code。内容涵盖 WSL 设置、开发工具安装、依赖配置及常见问题解决方法,助你顺利在本地环境中使用 Claude Code 提升编码效率。
655 1
Windows安装Claude Code

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等