Welcome to collectivesolver - Programming & Software Q&A with code examples. A website with trusted programming answers. All programs are tested and work.

Contact: aviboots(AT)netvision.net.il

Buy a domain name - Register cheap domain names from $0.99 - Namecheap

Scalable Hosting That Grows With You

Secure & Reliable Web Hosting, Free Domain, Free SSL, 1-Click WordPress Install, Expert 24/7 Support

Semrush - keyword research tool

Boost your online presence with premium web hosting and servers

Disclosure: My content contains affiliate links.

39,894 questions

51,825 answers

573 users

How to find whether an array include a pair of which product equals to N in C++

1 Answer

0 votes
#include <iostream>
#include <unordered_set>
 
bool ProductExists(int arr[], int size, int N) {
    if (size < 2)
        return false;
     
    std::unordered_set<int> set;
   
    for (int i = 0; i < size; i++) {
        if (arr[i] == 0 && N == 0)  {
            return true;
        }
        if (N % arr[i] == 0) {
            if (set.find(N / arr[i]) != set.end())
                return true;
            set.insert(arr[i]);
        }
    }
       
    return false;
}
 
int main()
{
    int arr[] = {5, 7, 13, 25, 9, 3, 4};
    int size = sizeof(arr) / sizeof(arr[0]);
    int N = 21;
 
    std::cout << (ProductExists(arr, size, N) ? "Yes" : "No");
}
 
 
 
 
/*
run:
 
Yes
 
*/

 



answered Jul 21, 2023 by avibootz
edited Jul 22, 2023 by avibootz
...