【C++】实现一个数组均分函数

在这之前我们有了解过make_move_iterator的使用方式,可以帮我们免去拷贝

cpp 复制代码
int main()
{
    std::list<std::string> s{"one", "two", "three"};

    std::vector<std::string> v1(s.begin(), s.end()); // copy

    std::vector<std::string> v2(std::make_move_iterator(s.begin()),
                                std::make_move_iterator(s.end())); // move

    std::cout << "v1 now holds: ";
    for (auto str : v1)
        std::cout << "\"" << str << "\" ";
    std::cout << "\nv2 now holds: ";
    for (auto str : v2)
        std::cout << "\"" << str << "\" ";
    std::cout << "\noriginal list now holds: ";
    for (auto str : s)
        std::cout << "\"" << str << "\" ";
    std::cout << '\n';
}
cpp 复制代码
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
template <typename T>
std::vector<std::vector<T>> splitVector(std::vector<T> &originalVector, size_t subVectorSize) {
    std::vector<std::vector<T>> result;

    if (subVectorSize == 0) {
        // Handle edge case where subVectorSize is 0
        return result;
    }

    size_t numSubVectors = originalVector.size() / subVectorSize;
    typename std::vector<T>::iterator it = originalVector.begin();

    for (size_t i = 0; i < numSubVectors; i++) {
        result.emplace_back(std::vector<T>(std::make_move_iterator(it), std::make_move_iterator(it + subVectorSize)));
        it += subVectorSize;
    }

    // Add the remaining elements as the last sub-vector
    if (it != originalVector.end()) {
        result.emplace_back(std::vector<T>(std::make_move_iterator(it), std::make_move_iterator(originalVector.end())));
    }

    return result;
}
int main() {
    std::vector<std::string> originalVector;
    // 填充原始数据
    for (int i = 0; i < 320; ++i) {
        originalVector.push_back("Data" + std::to_string(i)); // 假设你有一个名为 Data 的前缀并带有数字的字符串
    }
    std::vector<std::vector<std::string>> subVecs = splitVector(originalVector, 100);
    for (auto& val : subVecs)
    {
        std::cout << val.size() << std::endl;
    }
    std::cout << originalVector.empty() << std::endl; // 为false
    std::cout << "origin nums = " << originalVector.size() << ", origin nums not null = " << std::count_if(originalVector.begin(), originalVector.end(), [](const auto& res) {return res.size() > 0;}) << std::endl;
    originalVector.clear(); // 需要手动将原数组大小置为0
    return 0;
}




// 编译选项:g++ -std=c++11 3-3-8.cpp
C++ 复制代码
100                                        
100                                        
100                                        
20                                         
origin nums = 320, origin nums not null = 0

在你的代码中,当你使用 std::make_move_iterator 将原始向量 originalVector 中的元素移动到 new_vec 后,移动并不会改变原始向量的大小。相反,它只是将元素的所有权从一个容器转移到另一个容器,这意味着在移动后原始向量变为空(或者说内部元素被置空),但其大小并不会随之改变。

所以,在你的情况下,originalVector.size() 的结果仍然会显示为原始向量的初始大小,而不是 0,尽管元素已经被移走并且值为空。

如果你想要获取移动后的新向量 new_vec 的大小,可以使用 new_vec.size() 来获取新向量的元素个数。

相关推荐
白仑色1 分钟前
JavaScript案例(乘法答题游戏)
开发语言·javascript·游戏
一个会的不多的人1 小时前
C# NX二次开发:超级点控件使用详解
开发语言·c#
weixin_437499921 小时前
【PHP类的基础概念:从零开始学面向对象】
开发语言·php
打点计时器2 小时前
Onnx模型部署到Arm64进行推理
c++
chxii2 小时前
1.8 axios详解
开发语言·前端·javascript
Yang-Never2 小时前
设计模式 -> 策略模式(Strategy Pattern)
android·开发语言·设计模式·kotlin·android studio·策略模式
ikkkkkkkl2 小时前
LeetCode:209.长度最小的子数组&&3.无重复字符的最长子串
数据结构·c++·算法·leetcode
Java&Develop2 小时前
Java中给List<T> 对象集合去重
java·开发语言
非科班CPP程序员2 小时前
新手BUG:函数中 static 变量的赋值语句只会执行一次
数据结构·c++·算法
沐知全栈开发3 小时前
Perl 格式化输出
开发语言