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

51,859 answers

573 users

How to find the maximum repeating number in array with C

1 Answer

0 votes
#include <stdio.h>
#include <limits.h>

int MaxRepertingElement(int* array, int size) {
    for (int i = 0; i < size; i++) {
        array[array[i] % size] += size;
        // array[i] % size = 3 4 8 3 8 2 3 9 4 4 4 7 7 7 4 
        // array = [3, 4, 23, 48, 83, 2, 3, 54, 34, 19, 4, 7, 7, 7, 4]  
    }

    int max_element = INT_MIN, repeating = 0;

    for (int i = 0; i < size; i++) {
        if (array[i] > max_element) {
            max_element = array[i];
            repeating = i;
        }
    }

    for (int i = 0; i < size; i++) {
        array[i] = array[i] % size;
        // array = 3, 4, 8, 3, 8, 2, 3, 9, 4, 4, 4, 7, 7, 7, 4 // return original values

    }

    return repeating;
}


int main(void) {
    int array[] = { 3, 4, 8, 3, 8, 2, 3, 9, 4, 4, 4, 7, 7, 7, 4 };

    int size = sizeof(array) / sizeof(array[0]);

    printf("%d ", MaxRepertingElement(array, size));

    return 0;
}




/*
run:

4

*/

 



answered Aug 28, 2022 by avibootz
edited Aug 28, 2022 by avibootz

Related questions

1 answer 85 views
1 answer 98 views
1 answer 82 views
3 answers 147 views
2 answers 119 views
...