删除数组重复元素(js,java,c#)

编写一个高效去除数组重复元素的方法。
复制代码 代码如下:
<script>
function unique(data){
data = data || [];
var a = {};
for (var i=0; i<data.length; i++) {
var v = data[i];
if (typeof(a[v]) == 'undefined'){
a[v] = 1;
}
};
data.length=0;
for (var i in a){
data[data.length] = i;
}
return data;
}
function test(){
var arr = [9,1,3,8,7,7,6,6,5,7,8,8,7,4,3,1];
var arr1 = unique(arr);
alert(arr1.join(","));
}
test();
</script>

输出结果:
9,1,3,8,7,6,5,4
js数组去重就是把数组中重复的元素去掉:
复制代码 代码如下:
array.prototype.delrepeat=function(){
var newarray=new array();
var len=this.length;
for (var i=0;i<len ;i++){
for(var j=i+1;j<len;j++){
if(this[i]===this[j]){
j=++i;
}
}
newarray.push(this[i]);
}
return newarray;
}

  但是很明显这里有for循环内嵌了另一个for循环,在大数据量下肯定非常耗时!效率低下!经过查找和高人指点优化了一个新方法:
复制代码 代码如下:
array.prototype.delrepeat=function(){
var newarray=[];
var provisionaltable = {};
for (var i = 0, item; (item= this[i]) != null; i++) {
if (!provisionaltable[item]) {
newarray.push(item);
provisionaltable[item] = true;
}
}
return newarray;
}

  就是使用一个临时的provisionaltable对象,将数组的值作为provisionaltable对象的键值,如果相应的值不存在就将这个数组的值push到新数组中。

java

public static void main(string[] args) {  
        getdistinct(new int[] { 6, 7, 3, 6, 5, 2, 7, 8 });  
    }  
 
    static void getdistinct(int array[]) {  
        java.util.list list = new java.util.arraylist();  
        for (int i = 0; i < array.length; i++) {  
            if (!list.contains(array[i])) {  
                list.add(array[i]);  
                system.out.print(array[i] + " ");  
            }  
        }  
    }  
输出:6 7 3 5 2 8 

数组

    public boolean contains(object elem) {
 return indexof(elem) >= 0;
    }

    public int indexof(object elem) {
 if (elem == null) {
     for (int i = 0; i < size; i++)
  if (elementdata[i]==null)
      return i;
 } else {
     for (int i = 0; i < size; i++)
  if (elem.equals(elementdata[i]))
      return i;
 }
 return -1;
    }

使用c#查找数据中重复数据,删除数组重复项的解决方法。个人感觉,如果在数组不是很大的情况下,用正则替换还是最快的。原理就是先排序,再用正则替换重复。当然泛型+foreach是最好的选择,第二种方法很是不错,代码简洁,只是泛型的应用,如果再foreach就更好。

第一种方法:

        public static string[] removedup(string[] mydata)        {            if (mydata.length > 0)            {                array.sort(mydata); //先对数组进行排序                 int size = 1;  //定义删除重复项后的数组长度                  for (int i = 1; i < mydata.length; i++)                    if (mydata != mydata[i - 1])                        size++;                string[] mytempdata = new string[size];                int j = 0;                mytempdata[j++] = mydata[0];                for (int i = 1; i < mydata.length; i++) //遍历数组成员                      if (mydata != mydata[i - 1])  //如果相邻的两个不相等则放入新数组                         mytempdata[j++] = mydata;                return mytempdata;            }            return mydata;        } 

时间: 2024-10-22 01:33:48

删除数组重复元素(js,java,c#)的相关文章

javascript删除数组重复元素的方法汇总

  本文实例讲述了javascript删除数组重复元素的方法.分享给大家供大家参考.具体分析如下: 这里分享一个前端面试高频题,主要实现javascript删除数组重复元素.希望对初学者有所帮助 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 //数组去重的方法 Array.prototype.unique=function(){ //集中声明变量 var oldArr=this, newArr=[oldArr[0]], len=oldA

javascript删除数组重复元素的方法汇总_javascript技巧

本文实例讲述了javascript删除数组重复元素的方法.分享给大家供大家参考.具体分析如下: 这里分享一个前端面试高频题,主要实现javascript删除数组重复元素.希望对初学者有所帮助 //数组去重的方法 Array.prototype.unique=function(){ //集中声明变量 var oldArr=this, newArr=[oldArr[0]], len=oldArr.length, i=1; //过滤空数组 if(!len) return this; //过滤重复元素

Perl快捷删除数组重复元素

以前写过类似的博客: http://blog.csdn.net/three_man/article/details/34084361 今天拿出来,再好好剖析一下: 1. 构造一个含有重复元素的数组 my @arr1 = (1 .. 10); my @arr2 = (5 .. 15); # join multi array my @arr = (@arr1, @arr2); 2. 删除数组中的重复元素 sub removeRepeat { my $arrRef = shift; my %count

php array_flip()与array_uniqure()删除数组重复元素

方法如下:  代码如下 复制代码 $arr = array(----) ;// 假设有数组包含一万个元素,里面有重复的元素.   $arr = array_flip(array_flip($arr)); // 这样便可以删除重复元素.   究竟是怎么回事呢?来看下array_flip()的作用:array_flip()用于将一个数组的每个元素的键和值交换,如:  代码如下 复制代码   $arr1 = array("age" => 30, "name" =&g

php array_flip() 删除数组重复元素_php技巧

方法如下: $arr = array(----) ;//假设有一万个元素的数组,里面有重复的元素. $arr = array_flip(array_flip($arr)); //这样便可以删除重复元素. 究竟是怎么回事呢?来看下array_flip()的作用:array_flip()用于将一个数组的每个元素的键和值交换,如: $arr1 = array ("age" => 30, "name" => "快乐园"); $arr2 = a

PHP删除数组重复元素函数

function delsame(&$array) { $i = 0; while(isset($array[$i])) { $j = $i + 1; while(isset($array[$j])) { if($array[$i] == $array[$j]) //如果发现后面有重复的元素 { delmember($array, $j); //把它删除 $j--; //重新检查补上来的元素是否是重复的 } $j ++; } $i ++; } } //删除数组中重复元素的函数  代码如下 复制代

js删除数组重复元素的方法

  <script language="网页特效"> <!-- function each(list, fun){ for (var i = 0, len = list.length; i < len; i++) { fun(list[i], i); } }; var arr = [1,2,3,4,1,3] var t each(arr.sort(), function(o,i){ if(i>0 && o == t){ alert(&quo

js 高效去除数组重复元素示例代码

 有关使用js去除数组重复元素的文章在之前也有介绍过,下面有个不错示例,感兴趣的朋友可以参考下 代码如下: function unique(data){  data = data || [];  var a = {};  for (var i=0; i<data.length; i++) {  var v = data[i];  if (typeof(a[v]) == 'undefined'){  a[v] = 1;  }  };  data.length=0;  for (var i in a

[Js]删除数组指定元素

写在前面 在最近的项目中,有用到js对数组的操作,之前自己几乎没有用到这种方法,这里就记录一下,算是对学到的东西的一种总结吧. 数组对象splice方法 splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目.该方法会改变原始数组. 基本语法 arrayObject.splice(index,howmany,item1,.....,itemX)  参数说明 index:必需.整数,规定添加/删除项目的位置,使用负数可从数组结尾处规定位置. howmany:必需.要删除的项目数量.