剑指Offer40.最小的k个数 C++

1、题目描述

输入整数数组 arr ,找出其中最小的 k 个数。例如,输入4、5、1、6、2、7、3、8这8个数字,则最小的4个数字是1、2、3、4。
示例 1:

输入:arr = 3,2,1, k = 2

输出:1,2 或者 2,1
示例 2:

输入:arr = 0,1,2,1, k = 1

输出:0

2、VS2019上运行

排序法

cpp 复制代码
#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;

class Solution {
public:
    vector<int> getLeastNumbers(vector<int>& arr, int k) {
        // 创建一个大小为 k 的向量 vec,并初始化为 0
        vector<int> vec(k, 0);

        // 对原始数组 arr 进行排序
        sort(arr.begin(), arr.end());

        // 将排序后的前 k 个数复制到 vec 中
        for (int i = 0; i < k; ++i) {
            vec[i] = arr[i];
        }

        // 返回 vec 向量
        return vec;
    }
};

int main() {
    // 测试样例
    vector<int> arr = { 4, 5, 1, 6, 2, 7, 3, 8 };
    int k = 4;

    Solution sol;
    vector<int> result = sol.getLeastNumbers(arr, k);

    // 输出最小的 k 个数
    cout << "The least " << k << " numbers: ";
    for (int num : result) {
        cout << num << " ";
    }
    cout << endl;

    return 0;
}

The least 4 numbers: 1 2 3 4

相关推荐
折哥的程序人生 · 物流技术专研23 分钟前
Java面试85题图解版 · 特别篇:2026后端高频面试题复盘(算法底层逻辑+高并发架构设计全解析,附Java实战代码)
java·网络·数据库·算法·面试
玖玥拾1 小时前
C/C++ 基础笔记(十四)多态与模板编程
c语言·c++·多态·模板
想吃火锅10052 小时前
【leetcode】14.最长公共前缀js
算法·leetcode·职场和发展
Roann_seo%2 小时前
C++文件操作完全指南:从文本读写到二进制文件处理
开发语言·c++
坚果派·白晓明3 小时前
【鸿蒙PC】SDL3 适配:AtomCode + Skills 快速集成 NAPI 测试工具
c++·华为·ai编程·harmonyos·atomcode
云絮.3 小时前
数据库操作
数据库·mysql·算法·oracle
小林ixn3 小时前
LeetCode 206. 反转链表(迭代 + 递归详解)
算法·leetcode·链表
凡人叶枫3 小时前
Effective C++ 条款17:以独立语句将 newed 对象置入智能指针
java·linux·开发语言·c++·算法
凡人叶枫5 小时前
Effective C++ 条款16:成对使用 new 和 delete 时要采取相同形式
开发语言·c++·effective c++
菜鸟‍5 小时前
LeetCode 1 27 和 704 || 两数之和 移除元素 二分查找
算法·leetcode·职场和发展