-
-
Notifications
You must be signed in to change notification settings - Fork 14
Glasgow | Sheetal Kharab | Module-Complexity | Sprint 1 | Analyse and refactor #32
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: main
Are you sure you want to change the base?
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -1,14 +1,25 @@ | ||
| /** | ||
| * Finds common items between two arrays. | ||
| * | ||
| * Time Complexity: | ||
| * Space Complexity: | ||
| * Optimal Time Complexity: | ||
| * Time Complexity:O(n+m) it build set and loop through arrays once | ||
|
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. What's the complexity of
|
||
| * Space Complexity: store second array in set | ||
| * Optimal Time Complexity:O(m+n) | ||
|
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. We could also write O(max(m, n)) |
||
| * | ||
| * @param {Array} firstArray - First array to compare | ||
| * @param {Array} secondArray - Second array to compare | ||
| * @returns {Array} Array containing unique common items | ||
| */ | ||
| export const findCommonItems = (firstArray, secondArray) => [ | ||
| ...new Set(firstArray.filter((item) => secondArray.includes(item))), | ||
| ]; | ||
| // export const findCommonItems = (firstArray, secondArray) => [ | ||
| // ...new Set(firstArray.filter((item) => secondArray.includes(item))), | ||
| // ]; | ||
| // Refactored to use a Set for faster lookups, making the code more efficient | ||
| export const findCommonItems = (firstArray, secondArray) => { | ||
| const secondArraySet = new Set(secondArray); | ||
| const resultSet = new Set(); | ||
| for (const element of firstArray) { | ||
| if (secondArraySet.has(element)) { | ||
| resultSet.add(element); | ||
| } | ||
| } | ||
| return [...resultSet]; | ||
| }; | ||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -1,21 +1,35 @@ | ||
| /** | ||
| * Find if there is a pair of numbers that sum to a given target value. | ||
| * | ||
| * Time Complexity: | ||
| * Space Complexity: | ||
| * Optimal Time Complexity: | ||
| * Time Complexity: o(n2) the function use 2 nested loop | ||
| * Space Complexity:o(1)no additional significant memory used | ||
| * Optimal Time Complexity: O(n) — in the refactored version using a Set for lookups | ||
| * | ||
| * @param {Array<number>} numbers - Array of numbers to search through | ||
| * @param {number} target - Target sum to find | ||
| * @returns {boolean} True if pair exists, false otherwise | ||
| */ | ||
| // export function hasPairWithSum(numbers, target) { | ||
| // for (let i = 0; i < numbers.length; i++) { | ||
| // for (let j = i + 1; j < numbers.length; j++) { | ||
| // if (numbers[i] + numbers[j] === target) { | ||
| // return true; | ||
| // } | ||
| // } | ||
| // } | ||
| // return false; | ||
| // } | ||
|
|
||
| export function hasPairWithSum(numbers, target) { | ||
| for (let i = 0; i < numbers.length; i++) { | ||
| for (let j = i + 1; j < numbers.length; j++) { | ||
| if (numbers[i] + numbers[j] === target) { | ||
| return true; | ||
| } | ||
| const numbersNeeded = new Set(); // stores numbers we've already seen | ||
|
|
||
| for (const num of numbers) { | ||
| const requiredNumber = target - num; | ||
| if (numbersNeeded.has(requiredNumber)) { | ||
| return true; // found a pair! | ||
| } | ||
| numbersNeeded.add(num); // remember current number | ||
| } | ||
| return false; | ||
|
|
||
| return false; // no pair found | ||
| } |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
O(n) is the same as O(2n). We ignore the constant multiplier in big-O notation.