鱼C论坛

 找回密码
 立即注册
查看: 4337|回复: 10

如何对已知数组元素去除重复

[复制链接]
发表于 2012-11-17 19:40:16 | 显示全部楼层 |阅读模式
5鱼币
  1. #include <stdio.h>

  2. int main(void)
  3. {
  4.         int a[5][4] = {{1,2,2,3},{6,2,1,7},{2,6,7,8},{3,2,8,9},{5,6,7,1}};
  5.         int d=1,i,j,k = 0,Temp,b[20] = {0};
  6.     for(i= 0;i<5;i++)
  7.         {
  8.                 for(j=0;j<4;j++)
  9.                 {
  10.             b[k] = a[i][j];
  11.                         k++;
  12.                 }
  13.         }


  14.         for(i=0;i<19;i++)
  15.         {
  16.                 for(j =0;j<20-i;j++)
  17.                 {
  18.                         if(b[j] > b[j+1])
  19.                         {
  20.                                 Temp = b[j];
  21.                             b[j] =b[j+1];
  22.                                 b[j+1] =Temp;
  23.                         }

  24.                 }
  25.         }
  26.   
  27.         for(i =0;i<20;i++)
  28.                 printf("%d\n",b[i]);
  29. }
复制代码
意思就是将这个二维数组中相同元素去除………………如何编写,或者说说思路也行!!!谢谢了!!!!!

最佳答案

查看完整内容

ls的方法可行。 还有一些方法,考虑到数组中元素比较集中,可以这么做(根据要求可以调整方法)
小甲鱼最新课程 -> https://ilovefishc.com
发表于 2012-11-17 19:40:17 | 显示全部楼层
ls的方法可行。
还有一些方法,考虑到数组中元素比较集中,可以这么做(根据要求可以调整方法)
  1. #include <stdio.h>
  2. #include <string.h>

  3. #define PRIME 11 //可以调整
  4. #define UNEXISTNUM -1

  5. int main(int argc, char *argv[])
  6. {
  7.         int a[5][4] = {{1,2,2,3},{6,2,1,7},{2,6,7,8},{3,2,8,9},{5,6,7,1}};
  8.        
  9.         int i, j;
  10.         int hash_value[PRIME], hash_key;  
  11.        
  12.         memset( hash_value, UNEXISTNUM, sizeof(hash_value) );       
  13.        
  14.         for( i = 0; i < 5; ++i )
  15.         {
  16.                 for( j = 0; j < 4; ++j )
  17.                 {
  18.                         hash_key = (a[i][j] % PRIME) - 1;
  19.                         if( hash_value[hash_key] == UNEXISTNUM )
  20.                         {
  21.                                 hash_value[hash_key] = a[i][j];
  22.                         }
  23.                 }
  24.         }
  25.        
  26.         for( i = 0; i < PRIME; ++i )
  27.         {
  28.                 if( hash_value[i] != UNEXISTNUM )
  29.                 {
  30.                         printf( "%d\n", hash_value[i] );
  31.                 }               
  32.         }
  33.         return 0;
  34. }
复制代码

评分

参与人数 1鱼币 +5 收起 理由
格式天下 + 5 赞一个!

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2012-11-17 21:08:24 | 显示全部楼层
先对数组所有元素排序,比如从小到大排序,排序后所有重复元素都是连续排列的。之后再遍历一次数组就可以搞定,至于如何搞定,自己想吧,很容易的。用两个整数记录下标,一个是已扫描的原数组元素的下标,一个是新数组的最后一个元素的下一个位置
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2012-11-17 22:00:27 | 显示全部楼层
本帖最后由 格式天下 于 2012-11-17 22:09 编辑

没明白…………   删除连续的相同元素是怎么做到的,还有那个下标是干什么的?/?、?,兄台你的意思是不是在连续的情况下用连续的最后一个元素覆盖前面相同的元素…………这个算法复杂度有点高吧,有没有好点的方法嘞
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2012-11-17 22:47:00 | 显示全部楼层
  1. #include <stdlib.h>
  2. #include <stdio.h>

  3. void display( const char* msg, int data[], int size );
  4. int compare_ints( const void* a, const void* b );
  5. //返回处理后数组的元素个数
  6. int remove( int data[], int size );
  7. int main(){
  8.         int a[5][4] = {{1,2,2,3},{6,2,1,7},{2,6,7,8},{3,2,8,9},{5,6,7,1}};
  9.         int data[20];
  10.         int i,j,k=0;
  11.         int length;
  12.         for( i=0; i<5; ++i )
  13.                 for( j=0;j<4;++j )
  14.                         data[k++] = a[i][j];
  15.         display("before deal:", data,sizeof(data)/sizeof(data[0]));
  16.         qsort( data, sizeof(data)/sizeof(data[0]), sizeof(data[0]), compare_ints );
  17.         display("after sort:", data,sizeof(data)/sizeof(data[0]));
  18.         length = remove( data, sizeof(data)/sizeof(data[0]) );
  19.         display("result:", data,length);
  20. }

  21. void display( const char* msg, int data[], int size ) {
  22.         int i;
  23.         puts( msg );
  24.         for( i=0; i<size; ++i )
  25.                 printf("%d ",data[i]);
  26.         printf("\n");
  27. }

  28. int compare_ints( const void* a, const void* b ) {
  29.    int* arg1 = (int*) a;
  30.    int* arg2 = (int*) b;
  31.    if( *arg1 < *arg2 ) return -1;
  32.    else if( *arg1 == *arg2 ) return 0;
  33.    else return 1;
  34. }

  35. int remove( int data[], int size ) {
  36.         int src,dest;
  37.         for( dest=1, src=0; src<size ; ) {
  38.                 //move src to the first deferent data
  39.                 int tmp = data[src];
  40.                 while( src < size && data[src] == tmp ) ++src;
  41.                 if( src < size ) data[dest++] = data[src];
  42.         }
  43.         return dest;
  44. }
复制代码

评分

参与人数 1鱼币 +5 收起 理由
格式天下 + 5 赞一个!

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2012-11-17 22:50:38 | 显示全部楼层
suiyan 发表于 2012-11-17 19:40
ls的方法可行。
还有一些方法,考虑到数组中元素比较集中,可以这么做(根据要求可以调整方法)

如果考虑数字真的那么集中的话(题设中并没有强调这一点,可能数字会改变)
反正数字是从1~9的,不如直接搞个int result[10];初始数组全部清0,数到一个数就把相应下标的数据置1,最后检查哪些下标的数字不是0,输出下标就是了。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2012-11-18 01:35:31 | 显示全部楼层
本帖最后由 suiyan 于 2012-11-18 01:41 编辑

   正如ls所言,如果数字变了,可以这么改下,PRIME的值改变下,比如取23。顺便说下,这些方法都是有副作用的(包含其他功能,不是单纯实现lz所要求的),实现lz所要求的方法还是挺多的。。
  1. for( i = 0; i < 5; ++i )
  2. {
  3.            for( j = 0; j < 4; ++j )
  4.            {
  5.                        hash_key = (a[j] % PRIME) - 1;
  6.                         
  7.                       while( hash_value[hash_key] != a[j] && hash_value[hash_key] != UNEXISTNUM )
  8.                       {
  9.                                   hash_key++;
  10.                       }
  11.                       hash_value[hash_key] = a[j];
  12.           }
  13. }
复制代码

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2012-11-18 10:38:35 | 显示全部楼层
suiyan 发表于 2012-11-18 01:35
正如ls所言,如果数字变了,可以这么改下,PRIME的值改变下,比如取23。顺便说下,这些方法都是有副作用 ...

方法很经典呀……你是咋想到的   求指导…………
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2012-11-18 10:43:38 | 显示全部楼层

不错,谢谢啊!!!!很给力呀!!!!!!
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2012-11-18 17:18:58 | 显示全部楼层
格式天下 发表于 2012-11-18 10:38
方法很经典呀……你是咋想到的   求指导…………

额。也不是想到的吧,数据结构中有一章节是讲hash的,我只不过借用了下,lz可以看看数据结构这一章节,一定有些帮助的。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2012-11-18 18:34:56 | 显示全部楼层
suiyan 发表于 2012-11-18 17:18
额。也不是想到的吧,数据结构中有一章节是讲hash的,我只不过借用了下,lz可以看看数据结构这一章节,一 ...

学以致用,向你学习!!!唉,我的数据才看到图………………
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-11-16 08:58

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表