当前位置: 首页 > article >正文

【204】C++的vector删除重复元素

有些场景下 vector 中会有重复元素,而业务要求 vector 中避免出现重复元素。

我的算法如下:

  1. 获取当前 vector 的元素数量,并保存到一个 int 类型变量中。
  2. 开启一个外部循环,把 vector 从后向前循环,循环范围是最后一个到正数第二个,获取当前元素。
  3. 开启一个内部循环。从当前 vector 索引向前循环到第一个元素,获取排在前面的元素。
  4. 如果前面的元素中有和当前元素相等的,就删除当前元素,并终止内部循环。如果没有,就让内部循环继续运行直到结束。
  5. 重复第一步,直到外部循环结束。

因为在代码执行过程中,vector 的元素数量有可能变少,所以需要提前保存 vector 的元素数量。

从后向前循环,是为了保证在删除元素的时候,索引不会被影响并且能正确访问 vector 的元素。从前向后的话索引就无法保证能正确访问 vector 的元素了。

下面是以 int 整型为例自的代码:

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<vector>

int main(int argc, char** argv) {
	system("color 02");
	printf("argc=%d, argv=%s\n", argc, argv[0]);

	// Prepare the vector and the datas.
	const int LENGTH = 12;
	int arr[LENGTH] = { 1, 1, 1, 2, 3, 4, 4, 5, 6, 7, 7, 7 };
//	int arr[LENGTH] = { 12, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 1 };
	std::vector<int> intVector;
	for (int i = 0; i < LENGTH; i++) {
		intVector.push_back(arr[i]);
	}

	// Print vector content.
	printf("Before delete repeat:\n");
	for (std::vector<int>::iterator it = intVector.begin(); it != intVector.end(); it++) {
		int item = *it;
		printf("%d ", item);
	}
	printf("\n");

	// Delete the repeat item.
	int size = intVector.size();
	for (int i = size - 1; i >= 1; i--) {
		int current = intVector[i];
		// 查找前面一个重复的元素并删除。每次只删除一个
		for (int j = i - 1; j >= 0; j--) {
			int previous = intVector[j];
			if (current == previous) {
				intVector.erase(intVector.begin() + i);
				// Stop the 'j' for circle
				j = -1;
			}
		} // end for (int j = i - 1; j >= 0; j--)
	}

	// Print vector content.
	printf("Print vector content:\n");
	for (std::vector<int>::iterator it = intVector.begin(); it != intVector.end(); it++) {
		int item = *it;
		printf("%d ", item);
	}

	
	printf("\nEnd.\n");
	return 0;
}


http://www.kler.cn/news/312945.html

相关文章:

  • Java 基础篇:环境搭建、基本语法与面向对象编程
  • 【JPCS出版】第二届应用统计、建模与先进算法国际学术会议(ASMA2024,9月27日-29)
  • 华为OD机试真题- MELON的难题-2024年OD统一考试(E卷)
  • Leetcode 416. 分割等和子集(Medium)
  • 【第34章】Spring Cloud之SkyWalking分布式日志
  • 程序人生-2024我的个人总结
  • VScode开发GD32移植(标准库通用),保姆级!!!!!!!
  • OCR两篇革命之作
  • C#区分值类型和引用类型【一文读懂】
  • 第十三周:机器学习笔记
  • 【开发语言】写程序的两大基本原则(PO和NT原则)
  • three.js 热力图
  • Android Perfetto 学习
  • 聚焦于 Web 性能指标 TTI
  • 2024新动态:低代码开发占领新常态市场
  • ImportError: DLL load failed while importing _ssl: 找不到指定的模块的解决方法
  • man 命令:查看命令的帮助信息
  • 【学习资料】袋中共36个球,红白黑格12个,问能一次抽到3个红4个白5个黑的概率是多少?
  • 封装一个录音声音振动效果的组件
  • foc原理odrive驱动板的使用,以及功能介绍
  • 基于TRIZ的救援机器人轻量化设计
  • 搜索引擎onesearch3实现解释和升级到Elasticsearch v8系列(一)-概述
  • 翻唱技巧:AU和Cubase翻唱录制对轨技巧
  • Linux 系统进程理解——标识符,状态
  • uniapp中使用echarts 完整步骤,包括报错以及解决方案
  • 实验一:Windows下的IIS服务器配置和管理
  • 50页PPT麦肯锡精益运营转型五步法
  • 考研报名确认上传身份证户口本学历证明照片如何压缩裁剪
  • 聊聊Thread Local Storage
  • 代码随想录训练营第34天| 62.不同路径 、63. 不同路径 II