| |
|
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
| -> 数据结构与算法 -> L2-017 人以群分 (25 分)(c语言实现) -> 正文阅读 |
|
|
[数据结构与算法]L2-017 人以群分 (25 分)(c语言实现) |
|
该题目如下
如题所示,其中会先给数据的个数,所以先进行数据的录入,利用数组来存储数据中的活跃度,同时利用一个n来记录数组中元素的个数。 数据录入过程:
排序在这里选用库函数自带的qsort,否则不能达到该题所要求的时间要求(测试点四),手打快排无法满足该题时间要求 qsort(数组名,数组中元素的个数,数组每个元素所占的字节数量,自定义的inc函数) 代码实现如下
到这一步完成对数组的排序 根据题目要求,理解如下
n1代表外向人数,n2代表内向人数 而数组已经被我们排序,所以只需要从数组中提取需要的数据并相加即可 意为先从数组的前端提取n2个数字,记为sum1,然后剩余的数字为另一组记为sum2 由于数组已经被排序,所以我们清楚地知道sum2与sum1的大小必然是sum2>sum1,所以在这里不需要利用绝对值函数,直接进行sum2-sum1即可 代码的实现如下
利用手打快排能保证最终结果正确,但是无法通过测试点4 手打快排实现如下
|
|
|
|
|
| 上一篇文章 下一篇文章 查看所有文章 |
|
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
| 360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年11日历 | -2025/11/29 21:08:01- |
|
| 网站联系: qq:121756557 email:121756557@qq.com IT数码 |