数组重复的问题在任何编程中都会有碰到了,这里介绍C语言删除无序整型数组中的重复元素及时间复杂度,希望对各位有帮助。

遇到一个题,大概要求是写一个函数处理来去掉一个无序的整型数组(例如int i_arr[] = { 1, 2, 2, 3, 4, 2, 3, 5 };)中重复的元素,并返回最终的长度。

1 思路

看到这道题的时候,第一反应就是需要删除元素,然后联想到单链表。但是后面一想还是不划算,因为单链表还得先把数组中的元素遍历到链表节点中。

换一下思路,可以先创建另一个整型数组(大小和原数组一样),然后正向遍历数组中的元素,比较当前元素和它前面所有的元素是否重复,如果这个整数之前没有出现过,那么就放到新的数组中,于是有了小节2中的Method1;另外一种就是不需要创建新的数组,在正向遍历数组中的元素时,比较当前元素和它后面所有的元素是否重复,如果重复就把后面的所有元素向前移动(即覆盖),于是有了小节2中的Method2。

2 完整程序

程序中第104行的--j语句非常重要,这是为了避免当前元素连续出现3次(或以上)而没有被删除。

#include

#include

#include

#include "print.h"

int f_del1( int *i, int iLen );

int f_del2( int *i_f_del2, int len );

int main( int argc, char **argv )

{

//The test array.

int i_arr1[26] = { 1, 3, 2, 1, 2, 3, 4, 5, 5, 6, 7, 8, 12, 11, 22, 3, 7, 5, 13, 4, 5, 8, 7, 6, 23, 12 };

int i_arr2[26] = { 1, 3, 2, 1, 2, 3, 4, 5, 5, 6, 7, 8, 12, 11, 22, 3, 7, 5, 13, 4, 5, 8, 7, 6, 23, 12 };

int i_ar2r[26] = { 1, 2, 2, 3, 3, 3, 4, 5, 5, 6, 7, 8, 11, 11, 12, 13, 13, 13, 13, 14, 15, 15, 17, 18, 23, 24 };

int i_ar3r[26] = { 1, 2, 2, 3, 3, 3, 4, 5, 5, 6, 7, 8, 11, 11, 12, 13, 13, 13, 13, 14, 15, 15, 17, 18, 23, 24 };

//The length of .

int i_p_len = 0;

#if 1

i_p_len = f_del1( i_ar2r, 26 );

PRINT( "len=[%d].", i_p_len );

#endif

PRINT( "------------------------------\n" );

#if 1

i_p_len = f_del2( i_ar3r, 26 );

PRINT( "len=[%d].", i_p_len );

#endif

return 0;

}

//Method 1: Using malloc to init an array for storing the elements after deleting the repeated ones.

int f_del1( int *array, int iLen )

{

int i = 1;

int i_recycle = 0;

//Flags to store an element into the array i_f_del1.

int i_flag = 1;

//Length of the sorted array, name as i_f_del1.

int i_f_del1_len = 1;

//Init an array for storing the elements after deleting the repeated ones.

int *i_f_del1 = (int *)malloc( iLen*sizeof(int) );

//Init the first interger element.

*i_f_del1 = *array;

while( i < iLen )

{

i_flag = 1;

i_recycle = 0;

while( i_recycle < i )

{

if( array[i] == array[i_recycle ] )

{

i_flag = 0;

break;

}

}

//If i_flag equals 1, we should put the current element to the array i_f_del1.

if( i_flag )

{

i_f_del1[i_f_del1_len ] = array[i];

}

i;

}

#if 1

for( i=0; i

{

PRINT( "i_f_del1[%d]=[%d].", i, i_f_del1[i] );

}

#endif

return i_f_del1_len;

}

//Method 2: cover up the repeated elements.

int f_del2( int *i_f_del2, int len )

{

int i = 0, j = 0, k = 0;

for( i=0; i

{

for( j=i 1; j

{

if( i_f_del2[i] == i_f_del2[j] )

{

for( k=j 1; k < len; k )

{

i_f_del2[k-1] = i_f_del2[k];        //cover up

}

--len;

//Key step to avoiding the continuous elements repeated more than 2 times.

--j;

}

}

}

#if 1

for( i=0; i

{

PRINT( "i_f_del2[%d]=[%d].", i, i_f_del2[i] );

}

#endif

return len;

}

3 测试执行

使用《Linux C/C 工程中可生成ELF、动/静态库文件的通用Makefile》一文中的Makefile文件进行程序编译,当然也可以使用命令进行编译gcc int_del_repeat.c -o int_del_repeat。

4 时间复杂度

Method 2中的时间复杂度为O(N^2),Method 2中的时间复杂度为O(N^3)。

c语言去掉数组中重复的,C语言删除无序整型数组中的重复元素及时间复杂度相关推荐

  1. LeetCode:Largest Number - 求整型数组中各元素可拼合成的最大数字

    2019独角兽企业重金招聘Python工程师标准>>> 1.题目名称 Largest Number(求整型数组中各元素可拼合成的最大数字) 2.题目地址 https://leetco ...

  2. C++:找出一个整型数组中最大值。

    题目概述: 找出一个整型数组中最大值. 编程: #include< iostream> using namespace std; class array_max //声明类 { publi ...

  3. c语言使用指针改数组逆置,用指针作函数参数,编写函数,将一个整型数组中的元素全部逆置。...

    满意答案 singoboss 2013.06.16 采纳率:57%    等级:11 已帮助:3587人 先输入,然后逆序存放,再输出.#include"stdio.h"#defi ...

  4. java消除整型数组中重复的元素,排序后输出新数组

    法一: import java.util.Arrays; import java.util.Scanner;public class Main {public static void main(Str ...

  5. 整型数组中三个数的最大乘积

    题目:给定一个整形数组,在数组中找出由三个数组成的最大乘积. 示例1: 输入:{1,2,3} 输出: 6 示例2:{1,2,3,4} 输出: 24 ** 思路:先给数组排序,最大的数分为两种情况,一种 ...

  6. 找出整型数组中最大和最小值及其所在位置

    思路:要找最大值就需要设一个比数组中最小的数还要小的数,要找最小值就要设一个比数组中最大数还要大的数 (1)第一种方法(比较大小,交换位置) int a[] = {5, -9, 32, 77, 64, ...

  7. c定义一个整型数组_滨州学院C语言作业讲解有序数组插入

    点击蓝字 关注我们 + 滨州学院C语言作业详解 [问题描述]一个长度为11的整型数组中存放有10个从小到大排好序的整数:1 3 5 10 23 100 180 200 350 500.输入一个x,把它 ...

  8. C语言试题三十五之找出一维整型数组元素中最大的值和它所在的下标,最大的值和它所在的下标通过形参传回。主函数中x是数组名,n 是x中的数据个数,max存放最大值,index存放最大值所在元素的下标。

    1. 题目 请编写一个函数function,它的功能是:找出一维整型数组元素中最大的值和它所在的下标,最大的值和它所在的下标通过形参传回.主函数中x是数组名,n 是x中的数据个数,max存放最大值,i ...

  9. 输入两个由整型数构成的集合(元素个数均为5)分别放到数组A和B中,求这两个集合的交集(交集的元素由两个集合中的相同元素构成),最后输出交集中的元素。

    [问题描述]输入两个由整型数构成的集合(元素个数均为5)分别放到数组A和B中,求这两个集合的交集(交集的元素由两个集合中的相同元素构成),最后输出交集中的元素,要求在主函数中输入A和B数组,并输出交集 ...

最新文章

  1. 数据结构 - 把一个整数数组放到二叉树中使其有序(C++)
  2. 以太网实习_一位工科男在拿到华为实习生offer后的面经干货
  3. utxo模型_什么是UTXO?简析账户/余额模型和UTXO模型
  4. android+apk反编译+Mac
  5. 移动前端开发基础与优化
  6. typeof instanceof
  7. 【 2013华为杯编程大赛成都第三组前两题试题及答案】
  8. 硬解析和软解析 mysql_Oracle学习之shared pool--硬解析和软解析
  9. Cocos2D研究院之CCNode详解(三)
  10. 大数据是风口,但是该怎么规划架构?一般人都没注意到
  11. Spring MVC拦截器~~~登陆验证拦截
  12. CAN笔记(2) CAN特点
  13. rtsp连接断开_海康RTSP客户端连接分析
  14. 背壳BAKAZU 2013复古邮差风帆布休闲潮男腰包 A801BK 黑色 腰包胸包【图片 价格 品牌 报价】-京东商城...
  15. PSGAN——姿态稳健型可感知空间式生成对抗网络论文详细解读与整理
  16. 爆笑,2008最新一句话笑喷饭!
  17. 3D游戏建模:游戏建模都要用到哪些软件?
  18. 为了搞清深度学习的随机梯度下降我复习了下微积分
  19. 设计师思维 工程师思维_从设计思维到设计行为
  20. php考试报名,报名系统

热门文章

  1. 黑马程序员-Map集合
  2. ORA-24324 ORA-24323 ORA-01090
  3. Hyper-V passes Microsoft’s checkmarks exam: isn’t that always the case?
  4. 程序员的进阶课-架构师之路(10)-霍夫曼树
  5. java编写母亲节快乐_写在母亲节来临之际
  6. android java调用_关于Android中Java调用外部命令的三种方式
  7. 边缘计算计算机科学与技术,边缘计算现状与展望-ComputerScience-WayneStateUniversity.PDF...
  8. linux终端自动输入,linux shell自动输入实现
  9. Quick-Cocos2d-x初学者游戏教程2
  10. Linux日常运维(rsync通过服务连接,linux日志,screen)