网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

【C++学习】对二维数组进行排序-创新互联

1 问题描述

今天在学习 CUDA-NMS 算法时,遇到一个小问题,就是希望对一个二维数组进行排序,具体是这样的:

创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都网站设计、做网站、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的修武网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!

需要对存储目标框的二维数组进行排序,排序的方式是按照目标框的得分score从高往低排序,也就是结果数组的第二维的最后一个元素(dets[i][4])

(1)尝试使用sort()直接进行排序,无法编译通过

刚开始听人说,可以用sort()直接进行排序,不过试了一下好像无法编译通过,示例代码:CPP_sort

#include  // for std::sort

const int N = 3;
int arr[N][N] = {{3, 1, 7},
        {4, 1, 9},
        {5, 3, 2},
    };

int main()
{// Initialize the array with some values
    for (int i = 0; i< N; ++i)
        for (int j = 0; j< N; ++j)
            arr[i][j] = i * N + j;

    // Sort the array using a custom comparator function
    std::sort(arr, arr + N, [](const int a[], const int b[]) {return a[N-1] >b[N-1];
    });

    // The array is now sorted in descending order by the last element of the second dimension
    return 0;
}

我个人感觉这里面比较本质的原因是:二维数组(的一行)无法像一维数组的元素一样,在排序的时候进行swap交换,所以在编译的时候会报错;
我个人觉得比较看起来有关联的一句报错信息如下所示:
在这里插入图片描述
报错信息表示:error: invalid array assignment,很可能就是表示无法直接使用dets[i]的方式直接赋值数组的一行;

2 解决方法

代码示例:CPP_qsort_2d_array

Note:
这份代码示例没有用lambda表达式来书写,会使得代码的篇幅较长,之后会计划使用lambda表达式来进行改写。

你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧


当前标题:【C++学习】对二维数组进行排序-创新互联
文章来源:http://bjjierui.cn/article/ddpojp.html

其他资讯