麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

JavaScript獲取多個數組的交集簡單實例

2019-11-20 21:44:14
字體:
來源:轉載
供稿:網友
在項目中需要取得多個數組的交集,故本例只是適用于特定場景。比如A數組 var a = {1000,10001,10002,10003}; B數組 var b = {10002, 10003}; C數組var c = {10003}; 需要取得這三個數組的交集數組。
      具體思路為:先初始一個最小數組為A數組,元素個數最小的也是數組A的長度.然后再迭代各個數組,取得這幾個數組長度最短的為最小長度,同時得到長度最短數組。然后,迭代最小數組與各個數組,開始比較元素相等,使用計數器來判斷是否該元素在各個數組中都存在即為交集元素.
      思路比較簡單,但是可以實現多數組取得交集,代碼如下:

復制代碼 代碼如下:

<!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>
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 色婷婷久久久亚洲一区二区三区 | 亚洲成人伊人 | 92自拍视频 | 国产一级毛片高清 | 国产精品久久av | 国产羞羞网站 | 亚洲人成中文字幕在线观看 | 日韩中文字幕一区二区三区 | videos高潮| 一级黄色性感片 | 亚洲自拍第二页 | 男女一边摸一边做羞羞视频免费 | 精品成人免费视频 | 欧美人的天堂一区二区三区 | 国产精品视频一区二区三区四区五区 | 热re91久久精品国产99热 | 亚洲精中文字幕二区三区 | 91成人一区 | 久久免费观看一级毛片 | 欧美wwwwww| 色交视频 | 欧洲成人一区二区 | 97精品视频在线观看 | 久久久久久久久成人 | 草莓视频在线导航 | 日本高清无遮挡 | 久久久久久中文字幕 | 欧美 日韩 中文 | 日韩视频一区二区在线观看 | 久久久精品视 | 午夜久久久精品一区二区三区 | 涩涩99| 欧美成人一级片 | 精品久久久久久久久亚洲 | 激情网站视频 | 毛片网站视频 | av在线免费看网址 | 91久久久久久亚洲精品禁果 | 99999久久久久久 | 羞羞视频免费观看网站 | 国产精品视频久久久 |