Улучшение навыков программирования на JavaScript

JavaScriptJavaScriptBeginner
Практиковаться сейчас

This tutorial is from open-source community. Access the source code

💡 Этот учебник переведен с английского с помощью ИИ. Чтобы просмотреть оригинал, вы можете перейти на английский оригинал

Введение

В этом практическом занятии мы углубимся в мир программирования на JavaScript и попробуем повысить навыки в этом языке. Мы выполним различные упражнения и проекты, которые помогут нам понять основы языка, включая переменные, типы данных, функции и циклы. К концу практического занятия мы будем иметь твердый фундамент в программировании на JavaScript и будем готовы к более сложным программировательским задачам.


Skills Graph

%%%%{init: {'theme':'neutral'}}%%%% flowchart RL javascript(("JavaScript")) -.-> javascript/BasicConceptsGroup(["Basic Concepts"]) javascript/BasicConceptsGroup -.-> javascript/variables("Variables") javascript/BasicConceptsGroup -.-> javascript/data_types("Data Types") javascript/BasicConceptsGroup -.-> javascript/arith_ops("Arithmetic Operators") javascript/BasicConceptsGroup -.-> javascript/comp_ops("Comparison Operators") javascript/BasicConceptsGroup -.-> javascript/array_methods("Array Methods") subgraph Lab Skills javascript/variables -.-> lab-28339{{"Улучшение навыков программирования на JavaScript"}} javascript/data_types -.-> lab-28339{{"Улучшение навыков программирования на JavaScript"}} javascript/arith_ops -.-> lab-28339{{"Улучшение навыков программирования на JavaScript"}} javascript/comp_ops -.-> lab-28339{{"Улучшение навыков программирования на JavaScript"}} javascript/array_methods -.-> lab-28339{{"Улучшение навыков программирования на JavaScript"}} end

Функция для нахождения индекса вставки в отсортированном массиве

Для нахождения наименьшего индекса для вставки значения в массив и сохранения его сортировки используйте функцию sortedIndexBy(arr, n, fn) в JavaScript.

Эта функция нестрого проверяет, отсортирован ли массив по убыванию, а затем использует Array.prototype.findIndex(), чтобы найти соответствующий индекс на основе итераторной функции fn.

Вот код функции sortedIndexBy():

const sortedIndexBy = (arr, n, fn) => {
  const isDescending = fn(arr[0]) > fn(arr[arr.length - 1]);
  const val = fn(n);
  const index = arr.findIndex((el) =>
    isDescending ? val >= fn(el) : val <= fn(el)
  );
  return index === -1 ? arr.length : index;
};

Вы можете вызвать функцию с массивом объектов, значением для вставки и итераторной функцией.

Например, sortedIndexBy([{ x: 4 }, { x: 5 }], { x: 4 }, o => o.x) возвращает 0, что является индексом, где объект { x: 4 } должен быть вставлен, чтобы сохранить сортировку по свойству x.

Резюме

Поздравляем! Вы завершили практическое занятие по нахождению индекса вставки в отсортированном массиве на основе функции. Вы можете выполнить больше практических занятий в LabEx, чтобы повысить свои навыки.