递归地遍历数组并使用JavaScript返回项目数?
我们必须编写一个函数,说它searchRecursively()
接受一个数组和一个搜索查询,然后在嵌套数组中返回该搜索查询的计数。
例如,如果数组由-给定
const names = ["rakesh", ["kalicharan", "krishna", "rakesh", "james", ["michael", "nathan", "rakesh", "george"]]];
然后-
searchRecursively(names, ‘’rakesh’);
应该返回3,因为它在数组中总共出现3次。因此,让我们为该递归函数编写代码-
示例
const names = ["rakesh", ["kalicharan", "krishna", "rakesh", "james", ["michael", "nathan", "rakesh", "george"]]]; const searchRecursively = (arr, query, count = 0, len = 0) => { if(len < arr.length){ if(Array.isArray(arr[len])){ return searchRecursively(arr[len], query, count, 0); }; if(arr[len] === query){ return searchRecursively(arr, query, ++count, ++len); }; return searchRecursively(arr, query, count, ++len); }; return count; }; console.log(searchRecursively(names, "rakesh"));
输出结果
控制台中的输出将为-
3