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,943 questions

51,883 answers

573 users

How to check if a sequence of numbers is a Harmonic progression (reciprocals Arithmetic progression) in C++

1 Answer

0 votes
// a, b, c, d are HP if 1/a, 1/b, 1/c, 1/d are AP -> 1/a, 1/(a+diff), 1/(a+2*diff)...

#include <iostream>

int isHarmonicProgression(double arr[], int size) {
    if (size < 2) return 1;

    double diff = (1.0 / arr[1]) - (1.0 / arr[0]);

    for (int i = 2; i < size; i++) {
        if ((1.0 / arr[i]) - (1.0 / arr[i - 1]) != diff) {
            return 0; 
        }
    }
    
    return 1; 
}

int main() {
    double arr[] = {1.0 / 5, 1.0 / 10, 1.0 / 15, 1.0 / 20, 1.0 / 25}; 
    int size = sizeof(arr) / sizeof(arr[0]);

    (isHarmonicProgression(arr, size)) ? (std::cout << "Yes") : (std::cout << "No");
}



/*
run:

Yes

*/

 



answered Sep 22, 2024 by avibootz
edited Sep 22, 2024 by avibootz
...