news 2026/6/23 23:14:39

数组间距离计算(包含元素的最大距离)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
数组间距离计算(包含元素的最大距离)

以下是 Python 代码的 C++ 实现,主要逻辑包括计算数组相对于目标数组的距离,并根据该距离排序:

#include<iostream>#include<vector>#include<set>#include<algorithm>// 计算一个数组 arr 相对于目标数组 obj 的距离intcalculateDistance(conststd::vector<int>&arr,conststd::vector<int>&obj){std::set<int>objSet(obj.begin(),obj.end());// 使用集合进行快速成员检测intmaxGap=0;std::vector<int>indices;for(intnum:objSet){for(size_t i=0;i<arr.size();++i){if(arr[i]==num){indices.push_back(i);}}if(indices.size()>=2){std::sort(indices.begin(),indices.end());intgap=indices.back()-indices.front();// 最后一次出现与第一次出现的索引差if(gap>maxGap){maxGap=gap;}}// 如果数字只出现一次或未出现,gap 为 0,不影响 maxGap}returnmaxGap;}// 将 vector 中的每个元素按照其与 obj 的距离从小到大排序std::vector<std::vector<int>>sortVectorByDistance(conststd::vector<std::vector<int>>&vec,conststd::vector<int>&obj){std::vector<std::vector<int>>sortedVec=vec;std::sort(sortedVec.begin(),sortedVec.end(),[&obj](conststd::vector<int>&a,conststd::vector<int>&b){returncalculateDistance(a,obj)<calculateDistance(b,obj);});returnsortedVec;}intmain(){// 示例数据std::vector<std::vector<int>>myVector={{1,3,5,3,1,2,5},// 数字3的间隔: 索引1到3 -> 2; 数字5的间隔: 索引2到6 -> 4{2,4,6,8},// 没有数字在 obj 中,距离为 0{5,1,5,1,5},// 数字5的间隔: 索引0到4 -> 4{1,1}// 没有数字在 obj 中,距离为 0};std::vector<int>myObj={3,5};// 目标数组,我们关注数字3和5std::cout<<"原始 vector: "<<std::endl;for(size_t i=0;i<myVector.size();++i){intdist=calculateDistance(myVector[i],myObj);std::cout<<" 元素 "<<i<<": ";for(intval:myVector[i]){std::cout<<val<<" ";}std::cout<<", 距离: "<<dist<<std::endl;}std::vector<std::vector<int>>result=sortVectorByDistance(myVector,myObj);std::cout<<"\n排序后的 vector: "<<std::endl;for(size_t i=0;i<result.size();++i){intdist=calculateDistance(result[i],myObj);std::cout<<" 元素 "<<i<<": ";for(intval:result[i]){std::cout<<val<<" ";}std::cout<<", 距离: "<<dist<<std::endl;}return0;}

说明:

  1. calculateDistance 函数:
    · 将目标数组转换为 std::set 以方便查询。
    · 对每个目标数字,在数组中查找所有出现的位置并记录索引。
    · 如果出现次数 ≥ 2,计算最大间隔(最后出现位置 - 第一次出现位置),并更新最大间隔。
  2. sortVectorByDistance 函数:
    · 使用 std::sort 和自定义比较函数(Lambda 表达式),根据每个数组与目标数组的距离进行排序。
  3. 主函数:
    · 定义示例数据 myVector 和 myObj。
    · 输出原始数组及其距离,然后输出排序后的结果。

运行示例输出:

原始 vector: 元素 0: 1 3 5 3 1 2 5 , 距离: 4 元素 1: 2 4 6 8 , 距离: 0 元素 2: 5 1 5 1 5 , 距离: 4 元素 3: 1 1 , 距离: 0 排序后的 vector: 元素 0: 2 4 6 8 , 距离: 0 元素 1: 1 1 , 距离: 0 元素 2: 1 3 5 3 1 2 5 , 距离: 4 元素 3: 5 1 5 1 5 , 距离: 4

这样就用 C++ 完整实现了原 Python 代码的功能。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 4:44:15

Java智能优化引擎避坑指南:从业务痛点到技术实战心法

"为什么我的排班系统总是被投诉&#xff1f;配送路线规划怎么老是超预算&#xff1f;生产计划排程每次都要手动调整到半夜&#xff1f;" 【免费下载链接】awesome-java A curated list of awesome frameworks, libraries and software for the Java programming lang…

作者头像 李华
网站建设 2026/6/23 19:44:19

Vue3 Excel Editor:终极Excel风格数据编辑解决方案

还在为数据表格编辑功能而烦恼吗&#xff1f;想要在Vue3项目中实现类似Excel的直观操作体验&#xff1f;Vue3 Excel Editor正是你需要的完美工具&#xff01;这款专为Vue3设计的插件&#xff0c;能够以Excel风格高效显示和编辑对象数组数据&#xff0c;让数据管理工作变得前所未…

作者头像 李华
网站建设 2026/6/23 21:55:30

如何快速掌握大麦抢票助手:完整使用指南与实用技巧

还在为心仪演出门票秒空而苦恼吗&#xff1f;大麦抢票助手正是您需要的得力助手。这款基于Python和Selenium开发的自动化工具&#xff0c;能够智能模拟真实用户操作&#xff0c;显著提升热门演出门票的获取概率。本文将为您提供从环境搭建到成功抢票的全流程指导。 【免费下载链…

作者头像 李华
网站建设 2026/6/23 21:55:32

基于Spring Boot的智慧校园管理系统设计与实现

背景及意义 进入二十一世纪&#xff0c;互联网的飞速发展彻底重塑了人们的生活与信息传播模式&#xff0c;打破了传统地域限制带来的思想鸿沟&#xff0c;取代了骑马、信鸽等低效且不稳定的信息传递方式&#xff0c;推动各行业迈向信息化、数字化管理新阶段。当前&#xff0c;校…

作者头像 李华
网站建设 2026/6/23 21:54:58

Chinese-CLIP深度性能评估:三大基准数据集全面解析

项目技术全景 【免费下载链接】Chinese-CLIP 针对中文场景下设计和构建的CLIP模型变体&#xff0c;它能够完成跨视觉与文本模态的中文信息检索&#xff0c;并能够生成有效的多模态表示。这样的工具主要用于提升人工智能系统对于不同模态&#xff08;如图像和文本&#xff09;数…

作者头像 李华
网站建设 2026/6/23 18:14:52

import_3dm完整教程:轻松实现Rhino到Blender的无缝数据迁移

import_3dm完整教程&#xff1a;轻松实现Rhino到Blender的无缝数据迁移 【免费下载链接】import_3dm Blender importer script for Rhinoceros 3D files 项目地址: https://gitcode.com/gh_mirrors/im/import_3dm 还在为Rhino模型无法直接在Blender中使用而烦恼吗&#…

作者头像 李华