首页 > web前端 > js教程 > 正文

JavaScript获取多个数组的交集

高洛峰
发布: 2016-11-25 13:23:08
原创
2940人浏览过

在项目中需要取得多个数组的交集,故本例只是适用于特定场景。比如a数组 var a = {1000,10001,10002,10003}; b数组 var b = {10002, 10003}; c数组var c = {10003}; 需要取得这三个数组的交集数组。
      具体思路为:先初始一个最小数组为a数组,元素个数最小的也是数组a的长度.然后再迭代各个数组,取得这几个数组长度最短的为最小长度,同时得到长度最短数组。然后,迭代最小数组与各个数组,开始比较元素相等,使用计数器来判断是否该元素在各个数组中都存在即为交集元素.
      思路比较简单,但是可以实现多数组取得交集,代码如下:
 
html代码 
<!doctype html public "-//w3c//dtd html 4.0 transitional//en"> 
<html> 
 <head> 
  <title> new document </title> 
  <meta name="generator" content="editplus"> 
  <meta name="author" content=""> 
  <meta name="keywords" content=""> 
  <meta name="description" content=""> 
  <script> 
        function getvalues(obj){     
            var values = ""; 
            var l = obj.options.length; 
            for (var i=0; i<l; i++) { 
                if (i != (l-1)) { 
                    values += obj.options(i).value + "_"; 
                } 
                else { 
                    values += obj.options(i).value; 
                } 
            } 
            return values; 
        } 
 
        function _test() { 
            var ids = getvalues(document.all.aa); 
            var aa = _getintersection(ids); 
        } 
 
        function _getintersection(src) { 
            var tary = src.split("_"); 
            //最小数组 
            var minary = null; 
            var min = tary[0].split(",").length; //初始化第一个为长度最小的数组 
            minary = tary[0].split(","); 
            for (var i = 1, len = tary.length; i<len; i++) { 
                var temp = tary[i].split(","); 
                if (temp.length < min) { 
                    min = temp.length; 
                    minary = temp; 
                }  
            } 
            alert("最小数组:"+minary); 
             
            var ret = ''; 
            for (var i = 0, len = minary.length; i<len; i++) { 
                var srcnum = parseint(minary[i]); 
                var counter = 0; 
                for (var j = 0, ll = tary.length; j<ll; j++) { 
                    var tt = tary[j].split(","); 
                    for (var k = 0, l = tt.length; k<l; k++) { 
                        var tarnum = parseint(tt[k]); 
                        if (srcnum == tarnum) { 
                            counter ++; 
                        } 
                    } 
                } 
                if (counter == tary.length) { 
                    ret += srcnum + ","; 
                } 
            } 
            ret = strslice(ret, ','); 
            alert("交集是:" + ret); 
        } 
 
        //去掉结尾分隔符 
        function strslice(str, split){ 
            if ((str!=null && str!="") && (split!=' ')) 
                return ((str.charat(str.length-1) == split) ? str.substring(0, str.length-1) : str); 
            else 
                return str; 
        } 
  </script> 
 
 </head> 
 
 <body> 
    <button onclick="javascript:_test();">测试</button> 
 
    <select name="aa" id="aa" size="6" multiple> 
        <option value="10004,10005,10008,10009,10010,10018">测试1</option> 
        <option value="10004,10005,10006,10008,10009,10010,10018">测试2</option> 
        <option value="10004,10005,10006,10008,10009,10010,10018">测试3</option> 
        <option value="10004,10006,10008">测试4</option> 
        <option value="10004,10010,10018">测试5</option> 
    </select> 
 
 </body> 
</html> 

相关标签:
java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号