C++中unique函数作用及使用条件

本文详细介绍了STL库中的unique函数,包括其作用——在已排序容器中移除相邻重复元素但保留一个,并强调了使用前提——容器需排序。通过实例演示,展示了unique函数的实际效果和应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

unique是STL中很实用的函数之一

一、作用

unique的作用是“去掉”容器中相邻元素的重复元素“,但它又没有完整的去除,因为它会把重复的元素添加到容器末尾,而返回值是去重之后(最后一个数后面)的尾地址,如:

    int num[]={1,1,1,3,3};
    int ans=unique(num,num+5)-num;
    cout<<ans<<"\n";
    for(int i=0;i<=4;i++)cout<<num[i]<<" ";

输出:

2
1 3 1 3 3

易得:unique函数把重复的数,放到了去重后的数组中

二、使用条件

1、使用unique函数前,一定要将容器排序,不然unique函数返回值,可能与实际状况不符

2、unique函数,包左不包右,如:vector<int >v,unique(v.begin(),v.end())

    int num[]={1,2,3,2,3,1};
    int ans=unique(num,num+6)-num;

输出:ans=6,不等于3,说明unique是对排序数组进行去重的

愿以上对诸位有所帮助

定义:上下文无关文法是一种描述形式语言的数学模型,由四元组 G=(V,Σ,R,S) 构成。其中,V 是非终结符集合,Σ 是终结符集合,R 是产生式规则集合,S 是起始符号。 示例:在文档中,有 G(E) 和 G(S) 等上下文无关文法,用于描述表达式的结构。例如,G(E) 的定义如下: E→T∣E+T∣E−T T→F∣T∗F∣T/F F→(E)∣i 这里,E、T、F 是非终结符,而 +、−、∗、/、(、) 和 i 是终结符。该文法用于描述算术表达式的构造方式。 推导是根据文法规则从起始符号逐步生成句子的过程,分为两种类型: 最左推导:始终扩展当前最左边的未展开非终结符。 最右推导:始终扩展当前最右边的未展开非终结符。 例如,在 G(N) 的上下文无关文法中,数字串的最左推导过程可以表示为: N⇒ND⇒NDD⇒⋯⇒DDD⇒0DDD⇒01DD⇒012D⇒0127 语法树是通过图形方式展示字符串如何根据文法规则进行推导的结构。它清晰地反映了推导过程中的层次关系。例如,对于表达式 i+i∗i,其语法树可以直观地展示操作符和操作数之间的层次结构。 如果一个句子存在多个不同的语法树,即可以通过多种推导过程生成,那么这个文法就被认为是二义性的。例如,句子 iiiei 有两个可能的语法树,这表明该文法存在二义性。 在自动机理论中,确定化是指将非确定有限自动机(NFA)转换为确定有限自动机(DFA),以确保每个状态在读取输入符号时只有一个确定的转移路径。最小化则是指去除 DFA 中的冗余状态,以获得更简洁的模型。文档中提供了 DFA 确定化和最小化的详细步骤示例。 正则表达式是一种用于匹配字符串模式的工具。文档中给出了许多正则表达式的例子,例如 (0∣1)∗01,用于匹配所有以“01”结尾的由 0 和 1 组成的字符串。正则表达式在文本处理和模式匹配中具有广泛应用。 综上所述,编译原理不仅涉
在信息技术领域,UML(统一建模语言)是一种广泛使用的可视化建模工具,适用于软件工程,用于描述系统的需求、设计与实现。本大作业以“学生管理系统”为案例,深入探讨如何利用UML进行系统分析与设计。UML包含多种元素,如用例图、类图、对象图、序列图、协作图、状态图和活动图等。 在学生管理系统中,用例图是起点,它展示了系统的外部行为,即用户(如教师和学生)与系统之间的交互。例如,学生可以查询成绩、选课,教师可以管理课程、录入成绩。通过用例图,可明确系统的核心功能。 类图则用于描绘系统中类的结构及其关系。在该系统中,可能存在“学生”“教师”“课程”“成绩”等类,它们之间存在继承、关联、依赖等关系。例如,“学生”类包含“姓名”“学号”等属性,“教师”类包含“教师编号”“授课课程”等属性。这些关系定义了系统的数据模型。 对象图是类图的实例化,展示特定时刻系统中的对象及其关系。在学生管理系统中,对象图可具体展现某时刻学生、教师和课程的实际情况。 序列图和协作图用于表示对象间的交互顺序和方式。例如,在选课过程中,学生对象、课程对象和系统服务对象之间存在交互,序列图可清晰展示这一过程。 状态图和活动图则关注对象或系统的行为。学生可能有注册、在校、毕业等状态,状态图可描绘其状态变迁;活动图可描绘如成绩录入、选课确认等具体活动的流程。 大作业参考文档《大作业参考 - 学生管理系统.doc》会提供详细的步骤指导和案例分析,帮助理解并完成整个建模过程。它可能涵盖UML各图的绘制方法及如何将这些图整合为一套完整的系统设计方案。通过运用UML对“学生管理系统”进行建模,可系统地理解和设计系统架构,提高软件开发效率和质量,对提升软件工程的理解和技能有显著帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

科大天海

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值