Skip to content

burakboduroglu/data_structures_and_algorithms

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 

History

17 Commits
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

Welcome to Data Structures and Algorithms Repository ๐Ÿ‘‹

This repository contains the implementation of various data structures and algorithms in JavaScript. However, you can implement them in any programming language of your choice. If you find any issues or have any suggestions, feel free to open an issue or create a pull request.

What is Data Structures and Algorithms?

  • Data Structures are the way we store, organize, and manage data.
  • Algorithms are a set of steps to solve a particular problem.

Why should we use Data Structures and Algorithms?

They are essential tools for solving complex problems in computer science. They help us to write efficient code and improve the performance of our applications.

What is Big O Notation?

Big O Notation is a mathematical notation that describes the limiting behavior of a function when the argument tends towards a particular value or infinity. It is used to analyze the performance of an algorithm. For instance - O(1), O(n), O(log n), O(n^2), etc.

  • O(1) - Constant Time
  • O(n) - Linear Time
  • O(log n) - Logarithmic Time
  • O(n^2) - Quadratic Time
  • O(2^n) - Exponential Time

Best Case - The minimum time taken by an algorithm to solve a problem. (e.g., O(1))

Worst Case - The maximum time taken by an algorithm to solve a problem. (e.g., O(n^2))

Example 1 Here is an O(1) example:

function add(a, b) {
  return a + b;
}

Example 2 Here is an O(n) example:

function sum(arr) {
  let total = 0;
  for (let i = 0; i < arr.length; i++) {
    total += arr[i];
  }
  return total;
}

Each loop iteration increases the total time complexity by 1. Hence, the time complexity of the above function is O(n). If nested loops are used, the time complexity will be O(n^2).

Example 3 O(log n) example is binary search. We will cover this in the algorithms section.

Arrays

Arrays are a collection of elements stored in contiguous memory locations. They are used to store multiple values in a single variable. The elements in an array can be accessed using an index.

We are covering the following array challenges:

  • Reverse String
  • Palindromes
  • Integer Reversal
  • Sentence Capitalization
  • FizzBuzz
  • Max Profit
  • Array Chunk
  • Two Sum

Creating custom array:

  1. Create an array class.
  2. Implement the following methods:
    • constructor
    • push
    • pop
    • get
    • shift
    • deleteByIndex
  3. Test the methods.

You can find the implementation of the above challenges in the Arrays folder. In this folder, you will learn how to create custom arrays and implement the above challenges.

Reverse String:

Task reverse a given array and convert it to a string.

const myArray = ["B", "U", "R", "A", "K"];

const reverse = (arr) => {
  let reversed = [];
  for (let i = arr.length - 1; i >= 0; i--) {
    reversed.push(arr[i]);
  }
  return reversed;
};

console.log(reverse(myArray)); // [ 'K', 'A', 'R', 'U', 'B' ]

const reversedNameString = reverse(myArray).join("");
console.log(reversedNameString); // KARUB

Palindromes:

Task check if a given string is a palindrome. Palindrome is a word, phrase, or sequence that reads the same backward as forward.

const isPalindrome = (word) => {
  const reversedWord = word.split("").reverse().join("");
  if (word === reversedWord) {
    return true;
  }
  return false;
};

console.log(isPalindrome("racecar")); // true
console.log(isPalindrome("hello")); // false

Reverse Integer:

Task reverse a given integer.

// Solution 1
const reverseInteger1 = (num) => {
  return (reversed = num.toString().split("").reverse().join(""));
};

console.log(reverseInteger1(123)); // "321"

// Solution 2
const reverseInteger2 = (num) => {
  let reversed = 0;
  while (num > 0) {
    reversed = reversed * 10 + (num % 10);
    num = Math.floor(num / 10);
  }
  return reversed;
};

console.log(reverseInteger2(123)); // 321

Sentence Capitalization:

Task capitalize the first letter of each word in a sentence.

const capitalize = (str) => {
  arr = str.split("");
  arr.map((char, index) => {
    if (index === 0) {
      arr[index] = char.toUpperCase();
    } else if (arr[index - 1] === " ") {
      arr[index] = char.toUpperCase();
    }
  });

  return arr.join("");
};

console.log(capitalize("hello")); // "Hello"
console.log(capitalize("hello world")); // "Hello World"

FizzBuzz:

Task print numbers from 1 to n. If the number is divisible by 3, print "Fizz". If the number is divisible by 5, print "Buzz". If the number is divisible by both 3 and 5, print "FizzBuzz".

function fizzBuzz(num){
   if(num % 3 === 0) return "Fizz";
   else if(num % 5 === 0) return "Buzz";
   else if(num % 3 === 0 && num % 5 === 0) return "FizzBuzz";
   else return "Not a FizzBuzz";
}

console.log(fizzBuzz(3)); // Fizz
console.log(fizzBuzz(5)); // Buzz
console.log(fizzBuzz(15)); // FizzBuzz
console.log(fizzBuzz(7)); // Not a FizzBuzz

Max Profit:

Find the maximum profit that can be made by buying and selling a stock on a given day.

function maxProfit(arr){
    let minPrice = findMinNumber(arr)
    let maxProfit = 0;

    for(let i=0; i<arr.length; i++){
        if(arr[i] > minPrice){
            maxProfit = Math.max(maxProfit, arr[i] - minPrice);
        } else {
            minPrice = arr[i];
        }
    }
    return maxProfit;
}

function findMinNumber(arr){
    let min = arr[0];
    for(let i=0; i<arr.length; i++){
        if(arr[i] < min){
            min = arr[i];
        }
    }
    return min;
}

const prices = [7,1,5,3,6,4];
console.log(maxProfit(prices)); // 6