- 47
- 0
遇到一个算法;类似 var a= [1,2,3,4,4 ,5,5,5] 怎么处理成二位数组[[1],[2],[4,4],[5,5,5]]
我自己写的:额。。。循环两次,不太好
var a= [1,2,3,4,4,5,5,5];
var obj = {};
var arr = [];
for(var i = 0; i<a.length; i++) {
if(!obj[a[i]]){
obj[a[i]] = [];
}
obj[a[i]].push(a[i]);
}
for(var i in obj){
arr.push(obj[i]);
}
console.log(arr);
0
打赏
收藏
点击回答
您的回答被采纳后将获得:提问者悬赏的 11 元积分
- 共 0 条
- 全部回答
-
冷月星空ρ 普通会员 1楼
数组算法问题可以大致分为以下几个类型:
-
查找最小值或最大值:这可以通过使用快速排序或归并排序等排序算法实现。另一种方法是使用堆或优先队列来实现。
-
查找数组中的重复元素:这可以通过使用哈希表或集合来实现。哈希表的查找速度比集合快,但哈希表的插入和删除操作需要额外的时间。
-
插入和删除元素:这可以通过使用数组的扩展算法实现。例如,在插入元素时,可以首先找到数组的第一个元素,然后将新元素添加到前面的元素后面;在删除元素时,可以首先找到要删除的元素,然后将前面的所有元素向后移动一位。
-
统计数组中的元素数量:这可以通过遍历数组并使用计数器来实现。另一种方法是使用哈希表。
-
计算数组的平均值或中位数:这可以通过使用快速排序或归并排序等排序算法实现。
-
计算数组的最小值和最大值的差:这可以通过遍历数组并使用变量来实现。另一种方法是使用堆或优先队列。
-
计算数组的最长公共子序列:这可以通过使用动态规划和哈希表来实现。
以上只是一些基本的示例,实际的数组算法问题可能会更复杂,需要根据具体的需求来选择合适的方法。
-
更多回答
网站公告
- 扫一扫访问手机版
回答动态

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器更新之后。服务器里面有部分玩家要重新创建角色是怎么回事啊?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题函数计算不同地域的是不能用内网吧?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题ARMS可以创建多个应用嘛?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题在ARMS如何申请加入公测呀?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题前端小程序接入这个arms具体是如何接入监控的,这个init方法在哪里进行添加?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器刚到期,是不是就不能再导出存档了呢?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器的游戏版本不兼容 尝试更新怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器服务器升级以后 就链接不上了,怎么办?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器转移以后服务器进不去了,怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器修改参数后游戏进入不了,是什么情况?预计能赚取 0积分收益
- 回到顶部
- 回到顶部
