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;
}
相关推荐
兰令水17 分钟前
leecodecode【单调栈】【2026.6.12打卡-java版本】
java·开发语言·算法
TMT星球26 分钟前
魔法原子上交会首秀VLA K02大模型,完成具身智能从“执行”到“理解”的能力跃迁
人工智能·算法·机器学习
2301_7644413328 分钟前
番茄钟+AI:高效专注的秘密武器
人工智能·算法·数学建模·动态规划·交互
影寂ldy31 分钟前
C# 泛型委托
java·算法·c#
星马梦缘1 小时前
算法设计与分析 作业三 纯答案
算法
吴阿福|一人公司1 小时前
深度解析 Python 类变量修改的命名空间隔离
java·服务器·数据结构
雾沉川1 小时前
Visual C++ 运行库合集 v105.0 部署与故障排查技术指南
开发语言·c++·dll
不知名的老吴1 小时前
经典算法题之行星碰撞
数据结构·算法
丘山望岳1 小时前
剑起霜华——平衡二叉树(AVL树 )精讲
开发语言·数据结构·c++
西安邮电大学1 小时前
有关数组的经典算法题
java·后端·其他·算法·面试