【freecodecamp】更新仓库 Inventory Update

2024-04-20 07:48

本文主要是介绍【freecodecamp】更新仓库 Inventory Update,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目要求

freecodecamp 上面的一个练习题
题目要求是:
依照一个存着新进货物的二维数组,更新存着现有库存(在 arr1 中)的二维数组. 如果货物已存在则更新数量 . 如果没有对应货物则把其加入到数组中,更新最新的数量. 返回当前的库存数组,且按货物名称的字母顺序排列.

当你遇到困难的时候,记得查看错误提示、阅读文档、搜索、提问。

问题分析

1.更新的顺序要按照后面的数组来(for 循环)
2.在进行的过程中仓库也是会改变的
3.同样类型的话增加数量 否则在仓库中添加一个新的数组
4,添加完毕之后的数组要根据名字来进行排序

代码解决方案

1.一个添加新物品的函数,根据是否已经存在将单个数组元素添加进数组中

function updateSingle(singleArr){//输入为单个数组 arr1为全局变量中的仓库for(var j = 0 ; j < arr1.length;j++){if(singleArr.indexOf(arr1[j][1])>-1){//如果存在名字相同 只增加数量arr1[j][0] = arr1[j][0] + singleArr[0];return console.log('yes!');//直接返回 不运行下面的代码}}console.log('no');//原有仓库中没有 将数组作为元素添加进仓库(arr1)arr1.push(singleArr);
}

2.添加更新并且仓库

for(var x = 0; x < arr2.length; x++){updateSingle(arr2[x]);
}//这个运行完之后arr1的仓库就是最新的了

3.根据名字来进行排序

arr1.sort(function(value1,value2){var a = value1[1];var b = value2[1];a = a.toLowerCase();b = b.toLowerCase();return a > b;
});
完整代码:
function updateInventory(arr1, arr2) {function updateSingle(singleArr){for(var j = 0 ; j < arr1.length;j++){if(singleArr.indexOf(arr1[j][1])>-1){arr1[j][0] = arr1[j][0] + singleArr[0];return false;}}arr1.push(singleArr);}for(var x = 0; x < arr2.length; x++){updateSingle(arr2[x]);}arr1.sort(function(value1,value2){var a = value1[1];var b = value2[1];a = a.toLowerCase();b = b.toLowerCase();return a >b;});console.log(arr1);return arr1;
}// 仓库库存示例
var curInv = [[21, "Bowling Ball"],[2, "Dirty Sock"],[1, "Hair Pin"],[5, "Microphone"]
];var newInv = [[2, "Hair Pin"],[3, "Half-Eaten Apple"],[67, "Bowling Ball"],[7, "Toothpaste"]
];updateInventory(curInv, newInv);

角角兔towrabbit
欢迎评论点赞哦 ,评论还能给自己加分呢

这篇关于【freecodecamp】更新仓库 Inventory Update的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/919684

相关文章

Pandas利用主表更新子表指定列小技巧

《Pandas利用主表更新子表指定列小技巧》本文主要介绍了Pandas利用主表更新子表指定列小技巧,通过创建主表和子表的DataFrame对象,并使用映射字典进行数据关联和更新,实现了从主表到子表的同... 目录一、前言二、基本案例1. 创建主表数据2. 创建映射字典3. 创建子表数据4. 更新子表的 zb

解决Maven项目idea找不到本地仓库jar包问题以及使用mvn install:install-file

《解决Maven项目idea找不到本地仓库jar包问题以及使用mvninstall:install-file》:本文主要介绍解决Maven项目idea找不到本地仓库jar包问题以及使用mvnin... 目录Maven项目idea找不到本地仓库jar包以及使用mvn install:install-file基

Maven如何手动安装依赖到本地仓库

《Maven如何手动安装依赖到本地仓库》:本文主要介绍Maven如何手动安装依赖到本地仓库问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、下载依赖二、安装 JAR 文件到本地仓库三、验证安装四、在项目中使用该依赖1、注意事项2、额外提示总结一、下载依赖登

MySQL更新某个字段拼接固定字符串的实现

《MySQL更新某个字段拼接固定字符串的实现》在MySQL中,我们经常需要对数据库中的某个字段进行更新操作,本文就来介绍一下MySQL更新某个字段拼接固定字符串的实现,感兴趣的可以了解一下... 目录1. 查看字段当前值2. 更新字段拼接固定字符串3. 验证更新结果mysql更新某个字段拼接固定字符串 -

MySQL新增字段后Java实体未更新的潜在问题与解决方案

《MySQL新增字段后Java实体未更新的潜在问题与解决方案》在Java+MySQL的开发中,我们通常使用ORM框架来映射数据库表与Java对象,但有时候,数据库表结构变更(如新增字段)后,开发人员可... 目录引言1. 问题背景:数据库与 Java 实体不同步1.1 常见场景1.2 示例代码2. 不同操作

一文详解SQL Server如何跟踪自动统计信息更新

《一文详解SQLServer如何跟踪自动统计信息更新》SQLServer数据库中,我们都清楚统计信息对于优化器来说非常重要,所以本文就来和大家简单聊一聊SQLServer如何跟踪自动统计信息更新吧... SQL Server数据库中,我们都清楚统计信息对于优化器来说非常重要。一般情况下,我们会开启"自动更新

在MySQL执行UPDATE语句时遇到的错误1175的解决方案

《在MySQL执行UPDATE语句时遇到的错误1175的解决方案》MySQL安全更新模式(SafeUpdateMode)限制了UPDATE和DELETE操作,要求使用WHERE子句时必须基于主键或索引... mysql 中遇到的 Error Code: 1175 是由于启用了 安全更新模式(Safe Upd

Redis缓存问题与缓存更新机制详解

《Redis缓存问题与缓存更新机制详解》本文主要介绍了缓存问题及其解决方案,包括缓存穿透、缓存击穿、缓存雪崩等问题的成因以及相应的预防和解决方法,同时,还详细探讨了缓存更新机制,包括不同情况下的缓存更... 目录一、缓存问题1.1 缓存穿透1.1.1 问题来源1.1.2 解决方案1.2 缓存击穿1.2.1

Linux Mint Xia 22.1重磅发布: 重要更新一览

《LinuxMintXia22.1重磅发布:重要更新一览》Beta版LinuxMint“Xia”22.1发布,新版本基于Ubuntu24.04,内核版本为Linux6.8,这... linux Mint 22.1「Xia」正式发布啦!这次更新带来了诸多优化和改进,进一步巩固了 Mint 在 Linux 桌面

SpringCloud配置动态更新原理解析

《SpringCloud配置动态更新原理解析》在微服务架构的浩瀚星海中,服务配置的动态更新如同魔法一般,能够让应用在不重启的情况下,实时响应配置的变更,SpringCloud作为微服务架构中的佼佼者,... 目录一、SpringBoot、Cloud配置的读取二、SpringCloud配置动态刷新三、更新@R