亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

javascript - 一個JS的算法,求大神解答

瀏覽:99日期:2023-05-04 17:41:09

問題描述

有如下一個數組 [ {'id': 100006, 'value': '40,1666'}, {'id': 100017, 'value': '112,113'}, ]期望輸出如下結果 [’10006:40,100017:112’, ’10006:40,100017:113’, ’10006:1666,100017:112’, ’10006:1666,100017:113’, ]

亦或者輸入三個或者N個數組[ {'id': 100006, 'value': '40,1666'}, {'id': 100017, 'value': '112,113'}, {'id': 100018, 'value': '1,2'},]能夠輸出[’10006:40,100017:112’, ’10006:40,100017:113’, ’10006:40,100018:1’, ’10006:40,100018:2’, ’10006:1666,100017:112’, ’10006:1666,100017:113’, ’10006:1666,100018:1’, ’10006:1666,100018:2’, ’100017:112,100018:1’, ’100017:112,100018:2’, ’100017:113,100018:1’, ’100017:113,100018:2’,]

請問怎么實現這個函數?

附加:最好不論輸入數組長度都能正確的輸出相應的值(是所有數組的里的值都會被匹配一次),有些答案是固定取值0,1的,期望不要這樣。

問題解答

回答1:

有如下一個數組 [ {'id': 100006, 'value': '40,1666'}, {'id': 100017, 'value': '112,113'}, ]期望輸出如下結果 [’10006:40,100017:112’, ’10006:40,100017:113’, ’10006:1666,100017:112’, ’10006:1666,100017:113’, ]A

var arr = [ {'id': 100006, 'value': '40,1666'}, {'id': 100017, 'value': '112,113'}]var f = arr => { return arr.map(item => {let id = item.id; return item.value.split(’,’).map(v => `${id}:${v}`); });}var main = arr => { let res = f(arr)return res[0].reduce((acc, cur) => {let temp = res[1].map(e => `${cur},${e}`);return acc.concat(temp); }, [])}ScreenShot

javascript - 一個JS的算法,求大神解答

回答2:

核心就是:第一層遍歷數組 第二層遍歷對象屬性

回答3:

var data = [ {'id': 100006, 'value': '40,1666'}, {'id': 100017, 'value': '112,113'}, ];var cache = [];var output = [];data.forEach(function(value,index,array){ //拆分value值 cache[index] = array[index].value.split(’,’); console.log(cache[index]);})for(let i=0;i<cache.length;i++){ for(let j=0;j<2;j++){let text = data[0].id + ’:’ + cache[0][i] + ’,’ + data[1].id + ’:’ + cache[1][j];output.push(text); }}output.forEach(function(value,i,arr){ console.log(arr[i]);})回答4:

試了一下仿“純函數式”的代碼:

兩兩相配(這是答主想要的效果):

function transform(list) { return list.map(i => i.value .split(’,’) .map(j => `${i.id}:${j}`) ).reduce((acc, current, i, arr) => { current.forEach(L => { arr .filter((_, k) => k > i) .forEach(j => {j.forEach(R => { acc.push(`${L},${R}`)}) }) }) return acc }, [])}

另外,附加上NN相配:

function transform(list) { return list.map(i => i.value .split(’,’) .map(j => `${i.id}:${j}`) ).reduce((l, r) => ( l.length === 0 ? r : l.map(g => r.map(j =>`${g},${j}` ) ) .reduce((l, r) => l.concat(r), [] ) ), [])}回答5:

let install = arr => { return arr.map(item => {let id = item.id;return item.value.split(',').map( val => { return `${id}:${val}`;}); });};let merge = arr => { let temp = []; for( let [i,len] = [0,arr.length]; i < len; i++ ){for( let j = i + 1; j < len; j++ ){ let ta = arr[i].reduce((pre,cur) => {return [ `${pre},${arr[j][0]}`, `${pre},${arr[j][1]}`, `${cur},${arr[j][0]}`, `${cur},${arr[j][1]}`]; }); temp = temp.concat(ta);} } return temp;};let main = (arr = []) => { let nArr = install(arr); let result = merge(nArr); console.log(result);};main([ {'id': 100006, 'value': '40,1666'}, {'id': 100017, 'value': '112,113'}, {'id': 100018, 'value': '1,2'},]);//幫2樓完善了下,直接在控制臺輸出看結果就行了

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 欧美色爱综合 | 免费日本毛片 | 亚洲第一视频网 | 亚洲免费一区二区 | 国产网站麻豆精品视频 | 做爰成人五级在线视频 | 95视频在线观看免费 | 香蕉久久夜色精品国产尤物 | 亚洲成人美女 | 麻豆传媒2021精品传媒一区 | 亚洲免费影视 | 久久精品一区二区三区日韩 | 国产欧美日本在线观看 | 福利亚洲 | 亚洲人成高清毛片 | 欧美日韩一区二区在线视频 | 色九九亚洲偷偷动态图 | 免费中日高清无专码有限公司 | 国产精品视频第一页 | 日韩免费黄色片 | 午夜一级免费视频 | 国产亚洲精品自在久久不卡 | 男女啪啪免费体验区 | 麻豆视频在线观看网站 | 免费vip影院| 外国激情视频 | 黄色一级片免费观看 | 欧美亚洲另类久久综合 | 久久免费99精品久久久久久 | 亚洲精品99久久久久中文字幕 | 亚洲精品日韩精品一区 | 嘿嘿嘿视频免费网站在线观看 | 久久嫩模| 国产高清a毛片在线看 | 一级毛片无遮挡免费全部 | 尤蜜视频在线观看播放 | 毛片线看免费观看 | 日本毛片在线观看 | 一级特黄网站 | 1024视频色版在线网站 | 啪啪永久免费网 |