-
-
Notifications
You must be signed in to change notification settings - Fork 29
Glasgow | Sheetal Kharab | Module-Complexity | Sprint 2 | Improve code with precomputing #41
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 6 commits
b2a67d4
4aa063a
5212626
aad8ad2
deb4e14
3aa1e75
2ee4ae9
689643f
456a338
bf4ec56
c14c15e
6c22643
e1f0496
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 | ||
| * Space Complexity: store second array in set | ||
| * Optimal Time Complexity:O(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 | ||
| } |
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -1,13 +1,33 @@ | ||
| from typing import Set | ||
|
|
||
|
|
||
| def count_letters(s: str) -> int: | ||
| """ | ||
| count_letters returns the number of letters which only occur in upper case in the passed string. | ||
| """ | ||
| only_upper = set() | ||
| # only_upper = set() | ||
| # for letter in s: | ||
| # if is_upper_case(letter): | ||
| # if letter.lower() not in s: | ||
| # only_upper.add(letter) | ||
| # return len(only_upper) | ||
| uppercase_letters : Set[str] = set() | ||
| lowecase_letters : Set[str] = set() | ||
|
|
||
| # Precompute uppercase and lowercase letters | ||
| for letter in s: | ||
| if is_upper_case(letter): | ||
| if letter.lower() not in s: | ||
| only_upper.add(letter) | ||
| return len(only_upper) | ||
| uppercase_letters.add(letter) | ||
| elif letter.isalpha(): | ||
|
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. Nice - picking up the non-letter case
Author
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. Thank you.
Author
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. @OracPrime please review it. sorry for delay |
||
| lowecase_letters.add(letter) | ||
|
|
||
| # Count uppercase letters that don't appear in lowercase | ||
| count = 0 | ||
| for letter in uppercase_letters: | ||
| if letter.lower() not in lowecase_letters: | ||
| count +=1 | ||
|
|
||
| return count | ||
|
|
||
|
|
||
| def is_upper_case(letter: str) -> bool: | ||
|
|
||
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.
typo in name
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.
i change it. Thank you