6-2 sdut-C语言实验-递归函数之快速排序

简介: 6-2 sdut-C语言实验-递归函数之快速排序

6-2 sdut-C语言实验-递归函数之快速排序

分数 12

全屏浏览

切换布局

作者 maggie

单位 山东理工大学

本题要求实现一个快速排序函数。

给定 N ( N<= 100000) 个 int 范围内的整数,要求用快速排序对数据进行升序排列。

函数接口定义:

void Quick_sort (int array[], int l, int r);


其中 array[] 、 l 、r 都是用户传入的参数。 array[] 是需要排序的数组,数组长度不会超过100000; l 和 r 是需要进行排序的左端点和右端点。


裁判测试程序样例:

#include <stdio.h> void Quick_sort (int array[], int l, int r); int main() { int N, array[100000]; scanf("%d", &N); for(int i=0; i<N; i++) { scanf("%d", &array[i]); } Quick_sort(array, 0, N-1); for(int i=0; i<N; i++) { printf("%d ", array[i]); } printf("\n"); return 0; } /* 你的代码将被嵌在这里 */


输入样例:

1. 8
2. 49 38 65 97 76 13 27 49

输出样例:

在这里给出相应的输出。例如:

13 27 38 49 49 65 76 97


代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

struct NODE *creat_node(int n)
{
    struct NODE *tail,*p,*head;
    head=(struct NODE*)malloc(sizeof(struct NODE));
    head->next=NULL;
    tail=head;
    for(int i=0;i<n;i++)
    {
        p=(struct NODE*)malloc(sizeof(struct NODE));
        scanf("%d",&p->data);
        p->next=NULL;
        tail->next=p;
        tail=tail->next;
        
    }
    return head;
}
void printf_node(struct NODE *head)
{
    struct NODE*q;
    q=head->next;
    while(q)
    {
        if(q->next==NULL)
        {
            printf("%d\n",q->data);
        }
        else{
            printf("%d ",q->data);
        }
        q=q->next;\\max
    }
}
目录
相关文章
|
存储 负载均衡 Dubbo
深入理解Dubbo-4.Dubbo扩展SPI
深入理解Dubbo-4.Dubbo扩展SPI
212 1
|
9月前
|
机器学习/深度学习 人工智能 搜索推荐
探索人工智能在现代医疗中的革新应用
本文深入探讨了人工智能(AI)技术在医疗领域的最新进展,重点分析了AI如何通过提高诊断准确性、个性化治疗方案的制定以及优化患者管理流程来革新现代医疗。文章还讨论了AI技术面临的挑战和未来发展趋势,为读者提供了一个全面了解AI在医疗领域应用的视角。
198 11
|
5月前
|
存储 Linux iOS开发
macOS Ventura 13.7.5 (22H527) Boot ISO 原版可引导镜像下载
macOS Ventura 13.7.5 (22H527) Boot ISO 原版可引导镜像下载
379 1
macOS Ventura 13.7.5 (22H527) Boot ISO 原版可引导镜像下载
|
10月前
|
人工智能 Cloud Native 架构师
CNCF 宣布 Dapr 毕业
Dapr 是一个可移植的分布式应用运行时,提供集成 API,帮助开发者构建可靠和安全的分布式应用,提升生产力 20-40%。Dapr 于 2019 年由微软发布,并于 2021 年 11 月正式加入 CNCF。截至 2024 年 11 月 13 日,Dapr 已正式从 CNCF 毕业。它支持多种云原生技术,广泛应用于 Grafana、FICO、HDFC 银行等企业。
249 2
|
10月前
|
存储 供应链 算法
深入解析区块链技术的核心原理与应用前景
深入解析区块链技术的核心原理与应用前景
381 0
|
监控 Devops 持续交付
构建高效可靠的云基础设施:DevOps和SRE的最佳实践
【5月更文挑战第30天】在数字化转型的浪潮中,企业对云基础设施的依赖日益增加。本文探讨了如何通过结合DevOps和Site Reliability Engineering(SRE)的最佳实践来构建一个高效、可靠且灵活的云环境。文章首先概述了DevOps和SRE的核心原则,接着提出了一系列策略来优化云资源的管理、自动化流程、以及提高系统的弹性。最后,文中将分享一些成功的案例分析,以帮助读者理解这些原则在实际场景中的应用。
|
Cloud Native 关系型数据库 分布式数据库
数据库性能诊断工具DBdoctor通过阿里云PolarDB产品生态集成认证
DBdoctor(V3.1.0)成功通过阿里云PolarDB分布式版(V2.3)集成认证,展现优秀兼容性和稳定性。此工具是聚好看科技的内核级数据库性能诊断产品,运用eBPF技术诊断SQL执行,提供智能巡检、根因分析和优化建议。最新版V3.1.1增加了对PolarDB-X和OceanBase的支持,以及基于cost的索引诊断功能。PolarDB-X是阿里巴巴的高性能云原生分布式数据库,兼容MySQL生态。用户可通过提供的下载地址、在线试用链接和部署指南体验DBdoctor。
602 0
|
Rust Linux 开发工具
Rust安装
该文介绍了如何在Linux、mac和Windows上安装Rust编程语言。在Linux和mac系统中,可以通过运行一个curl命令自动下载并安装;在Windows上,需从官方网站下载安装包。安装完成后,使用`rustc --version`检查Rust版本以确认安装成功。此外,还提到了如何更新Rust(使用`rustup update`)和卸载(使用`rustup self uninstall`)以及查看官方文档(运行`rustup doc`)。推荐的开发工具有Visual Studio Code和JetBrains CLion,需要安装Rust插件。
|
canal SQL 消息中间件
阿里Canal框架(数据同步中间件)初步实践
阿里Canal框架(数据同步中间件)初步实践
1146 79
阿里Canal框架(数据同步中间件)初步实践
|
Linux 网络安全 网络虚拟化
Centos 7 环境实现内网服务访问1
Centos 7 环境实现内网服务访问
327 0