Domanda è ordinare l'array in base alla frequenza di elementi. Ad esempio, se la matrice di ingresso èordina la matrice in ordine decrescente di frequenza di occorrenza degli elementi in C
{ 2, 3, 2, 4, 5, 12, 2, 3, 3, 3, 12 }
quindi modificare l'array:
{ 3, 3, 3, 3, 2, 2, 2, 12, 12, 4, 5 }
Ho scritto il codice per questo e funziona correttamente, ma si sta usando un sacco di spazio e ha altissima complessità.
Non sono soddisfatto di questa soluzione e della logica che ho applicato per questo. Se qualcuno aiuta a ottimizzare questo codice o fornire una logica migliore.
il mio codice è:
#define _CRT_SECURE_NO_WARNINGS // this line to work code in visual studio
#include <stdio.h>
int main() {
/*
* n = number of integer
* i = loop variable
* j = inner loop variable
* c = number of distinct input
* buf = temprary storage for input value
* k = possibility of frequency of any no.
*/
int n, i, j, c = 0, buf, k;
int b; //act as flag
int arr[100] = { 0 };
int stack[200] = { 0 };
int top = -1;
printf("Enter the size of array(integer between 1-100):");
scanf("%d", &n);
n *= 2;
printf("----------Enter the elements in the array----------\n\n");
for (i = 0; i < n; i += 2) {
b = 0;
printf("Enter the element:");
scanf("%d", &buf);
for (j = 0; j <= i; j += 2) {
if (arr[j] == buf) {
arr[j + 1]++;
b = 1;
}
}
if (b == 0) {
c++;
arr[c * 2 - 2] = buf;
arr[c * 2 - 1]++;
}
}
for (i = 0; i < c * 2; i++)
printf("%d ", arr[i]);
//input done in form of (element,times of occurence i.e. frequency),to print array, write this outside of comment:
//for (i = 0; i < c * 2; i++) printf("%d ", arr[i]);
for (k = 1; k < n/2; k++) { //checking for possible frequencies
for (j = c * 2 - 1; j > 0; j -= 2) {
//locations(index) to check in array for frequency
//left to right, so with same frequency no.,which occurred first will push in last.
if (arr[j] == k)
stack[++top] = j; //pushing(index of frequency) into stack in increasing order of frequency
}
}
//to print stack, write this outside of comment:
//printf("\nstack\n");
//for (i = top; i > -1; i--) printf("%d ",stack[i]);
//printing of elements in there decreasing order of frequency(pop from stack)
//we have to print element, number of times of its frequency
printf("\n\n----------Output array in sorted order of there frequency----------\n");
for (top; top > -1; top--) {
for (j = arr[stack[top]]; j > 0; j--)
printf("%d ", arr[stack[top] - 1]);
}
}
Sei limitato a 'C' solo? Se 'C++' è permesso, dove puoi usare 'std :: map' e' qsort', puoi farlo in 15 righe di codice – mvp
Leggi: [Ordina elementi per frequenza | Set 2] (http://www.geeksforgeeks.org/sort-elements-by-frequency-set-2/) –
sì perché non so C++ a tutti ... ma si può sugest con C++ per gli altri .. bt sicuramente non riuscirò a capirlo ... –