Skip to content
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

Count pairs with given sum #10282

Merged
merged 23 commits into from
Oct 12, 2023
Merged

Count pairs with given sum #10282

merged 23 commits into from
Oct 12, 2023

Conversation

siddwarr
Copy link
Contributor

Describe your change:

I have added the solution to the problem for counting the no of pairs in an array with the given sum in the most optimal way

  • Add an algorithm?
  • Fix a bug or typo in an existing algorithm?
  • Documentation change?

Checklist:

  • I have read CONTRIBUTING.md.
  • This pull request is all my own work -- I have not plagiarized.
  • I know that pull requests will not be merged if they fail the automated tests.
  • This PR only changes one algorithm file. To ease review, please open separate PRs for separate algorithms.
  • All new Python files are placed inside an existing directory.
  • All filenames are in all lowercase characters with no spaces or dashes.
  • All functions and variable names follow Python naming conventions.
  • All function parameters and return values are annotated with Python type hints.
  • All functions have doctests that pass the automated testing.
  • All new algorithms include at least one URL that points to Wikipedia or another similar explanation.
  • If this pull request resolves one or more open issues then the description above includes the issue number(s) with a closing keyword: "Fixes #ISSUE-NUMBER".

@algorithms-keeper algorithms-keeper bot added the awaiting reviews This PR is ready to be reviewed label Oct 11, 2023
@cclauss
Copy link
Member

cclauss commented Oct 11, 2023

I am lost. What is the value of solving this? In what situation would this algorithm be useful?

The first half of the algorithm could be a one-liner by using a defaultdict or a Counter.

>>> pairs_with_sum([1,7,6,2,5,4,3,1,9,8],7)
4
"""
d: dict = {}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
d: dict = {}
d = {}

This type is inferred. Also try to use more descriptive variable names

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So I had to add that because it wasn't passing all the three tasks. I know we don't have to mention the type but I did so just to pass all the three tasks

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It gave some type not specified error

d[i] -= 1
if req_sum - i in d and d[req_sum - i] != 0:
ans += d[req_sum - i]
d[i] += 1
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You are subtracting one, and then adding one after an irrelevant if statement. Why?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So the reason I included that is because let's say the given number is 8 and you have 4 in your array. Now if u don't decrement d[4] by 1 then from the code it will check if 4 exists in the dictionary and as it does ans will be incremented. So even though there is only one 4 in the array it will still be considered. I could remove that and put if d[req-i]!=1

@siddwarr
Copy link
Contributor Author

I am lost. What is the value of solving this? In what situation would this algorithm be useful?

The first half of the algorithm could be a one-liner by using a defaultdict or a Counter.

This is the solution to an array leetcode problem. Yes you can use defaultdict for the first half. I just thought this will be more descriptive and easier to comprehend. I can change that. I think this problem is good for beginners to understand why hashing is required for these types of array questions

@cclauss
Copy link
Member

cclauss commented Oct 12, 2023

This is the solution to an array leetcode problem.

Please add a URL to the problem in the docstring at the top of the file as recommended in CONTRIBUTING.md.

Please use a defaultdict or Counter as this repo is for visitors who want to study quality algorithms.

If reviewers are confused by it then the code or its documentation must be improved before it can be merged.

@algorithms-keeper algorithms-keeper bot added the tests are failing Do not merge until tests pass label Oct 12, 2023
@siddwarr
Copy link
Contributor Author

This is the solution to an array leetcode problem.

Please add a URL to the problem in the docstring at the top of the file as recommended in CONTRIBUTING.md.

Please use a defaultdict or Counter as this repo is for visitors who want to study quality algorithms.

If reviewers are confused by it then the code or its documentation must be improved before it can be merged.

So when I'm using defaultdict it says it needs type annotation for d. This was the same error I was getting before also thats the reason i didnt use defaultdict before. How do I fix this

@siddwarr
Copy link
Contributor Author

This is the solution to an array leetcode problem.

Please add a URL to the problem in the docstring at the top of the file as recommended in CONTRIBUTING.md.
Please use a defaultdict or Counter as this repo is for visitors who want to study quality algorithms.
If reviewers are confused by it then the code or its documentation must be improved before it can be merged.

So when I'm using defaultdict it says it needs type annotation for d. This was the same error I was getting before also thats the reason i didnt use defaultdict before. How do I fix this

I have added the problem link in the docstring

Comment on lines 6 to 7
Count the no of pairs in a given array with given sum
Problem URL- https://practice.geeksforgeeks.org/problems/count-pairs-with-given-sum5022/0
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
Count the no of pairs in a given array with given sum
Problem URL- https://practice.geeksforgeeks.org/problems/count-pairs-with-given-sum5022/0
Given an array of integers and an integer req_sum, find the number of pairs of array
elements whose sum is equal to req_sum.
https://practice.geeksforgeeks.org/problems/count-pairs-with-given-sum5022/0

@algorithms-keeper algorithms-keeper bot removed the tests are failing Do not merge until tests pass label Oct 12, 2023
@cclauss cclauss enabled auto-merge (squash) October 12, 2023 09:08
@cclauss cclauss disabled auto-merge October 12, 2023 09:08
@cclauss cclauss enabled auto-merge (squash) October 12, 2023 09:08
@cclauss cclauss merged commit 09ce6b2 into TheAlgorithms:master Oct 12, 2023
@algorithms-keeper algorithms-keeper bot removed the awaiting reviews This PR is ready to be reviewed label Oct 12, 2023
@siddwarr siddwarr deleted the count_pairs_with_given_sum branch October 12, 2023 10:12
sedatguzelsemme pushed a commit to sedatguzelsemme/Python that referenced this pull request Sep 15, 2024
* added power_of_4

* deleted power_of_4

* added pairs_with_given_sum

* [pre-commit.ci] auto fixes from pre-commit.com hooks

for more information, see https://pre-commit.ci

* updated the comment

* updated return hint

* updated type hints

* updated the variable

* updated annotation

* updated code

* updated code

* [pre-commit.ci] auto fixes from pre-commit.com hooks

for more information, see https://pre-commit.ci

* added the problem link and used defaultdict

* [pre-commit.ci] auto fixes from pre-commit.com hooks

for more information, see https://pre-commit.ci

* corrected import formatting

* [pre-commit.ci] auto fixes from pre-commit.com hooks

for more information, see https://pre-commit.ci

* Update pairs_with_given_sum.py

* Update data_structures/arrays/pairs_with_given_sum.py

---------

Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
Co-authored-by: Christian Clauss <cclauss@me.com>
@isidroas isidroas mentioned this pull request Jan 25, 2025
14 tasks
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants