c++编程:数组元素去重,逆序输出

c++编程:数组元素去重

题目要求

输入若干个整数,先对所有数字去重 ,再进行从小到大升序排序,最后按空格分隔输出结果。

erase删除区间元素

复制代码
int main() {
    vector<int> nums = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};

    // 删除下标 2 到 5 的元素(包含2和5)
    // erase(first, last) 删除 \[first, last) 区间
    nums.erase(nums.begin() + 2, nums.begin() + 6);
    
    // 输出结果
    for(int i = 0; i < nums.size(); i++) {
        cout << nums[i] << " ";
    }
   // 输出:0 1 6 7 8 9
cpp 复制代码
#include<bits/stdc++.h>   
using namespace std;       

int main() {                
    int n;                   // 定义整型变量 n,用于临时存储每次输入的数字
    vector<int> v;           // 定义一个整型向量 v,用于存储所有输入的数字
    
    // 循环读取:不断从标准输入读取整数,直到文件结束(EOF)
    // cin >> n 会返回 cin 对象,当读取失败(如遇到 EOF)时,条件为 false
    while(cin >> n) {
        v.push_back(n);      // 将读取到的数字 n 添加到向量 v 的末尾
    }
    // 循环结束后,v 中存储了所有输入的数字(可能有重复)
    
    // 排序:将向量中的元素按升序排列
    // v.begin() 指向第一个元素,v.end() 指向最后一个元素的下一个位置
    sort(v.begin(), v.end());
    // 排序后,相同的元素会相邻排列,例如:[1, 1, 2, 2, 3, 3, 4]
    
    // 去重:将相邻的重复元素移到末尾,返回指向第一个重复元素的迭代器
    // unique 不会真正删除元素,只是移动位置
    vector<int>::iterator last = unique(v.begin(), v.end());
    // unique 执行后,向量变为:[1, 2, 3, 4, 1, 2, 3]
    // last 指向第一个重复元素的位置(即值为 1 的那个位置)
    
    // 删除重复元素:删除从 last 到末尾的所有元素
    // 左闭右开区间 [last, v.end()) 包含 last,不包含 v.end()
    v.erase(last, v.end());
    // 删除后,向量变为:[1, 2, 3, 4]
    
    // 输出去重后的所有元素
    for(int i = 0; i < v.size(); i++) {
        cout << v[i] << " ";     // 输出每个元素,后面跟一个空格
    }
    
    return 0;               
  1. 输入完所有数字后,按 回车

  2. 然后按 Ctrl+Z (Windows)或 Ctrl+D(Linux/Mac)

  3. 再按一次 回车,程序就会继续执行

c++编程:逆序输出(先 reverse 再正序输出)

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

int main() {
    vector<int> v = {1, 2, 3, 4, 5};
    
    // 反转整个向量
    reverse(v.begin(), v.end());
    
    // 正序输出(此时已经是逆序)
    for(int i = 0; i < v.size(); i++) {
        cout << v[i] << " ";
    }
    // 输出:5 4 3 2 1
    
    return 0;
}
相关推荐
杜子不疼.5 小时前
【C++ AI 大模型接入 SDK】 - DeepSeek 模型接入(上)
开发语言·c++·chatgpt
石山代码6 小时前
C++ 内存分区 堆区
java·开发语言·c++
心中有国也有家6 小时前
cann-recipes-infer:昇腾 NPU 推理的“菜谱集合”
经验分享·笔记·学习·算法
绝知此事7 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
碧海银沙音频科技研究院7 小时前
通话AEC与语音识别AEC的软硬回采链路
深度学习·算法·语音识别
csdn_aspnet8 小时前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展
LuminousCPP8 小时前
数据结构 - 线性表第四篇:C 语言通讯录优化升级全记录(踩坑 + 思考)
c语言·开发语言·数据结构·经验分享·笔记·学习
张小姐的猫8 小时前
【Linux】多线程 —— 线程互斥
linux·运维·服务器·c++
AI算法沐枫9 小时前
深度学习python代码处理科研测序数据
数据结构·人工智能·python·深度学习·决策树·机器学习·线性回归