diff options
| author | Martial Simon <msimon_fr@hotmail.com> | 2025-09-15 01:08:27 +0200 |
|---|---|---|
| committer | Martial Simon <msimon_fr@hotmail.com> | 2025-09-15 01:08:27 +0200 |
| commit | c9b6b9a5ca082fe7c1b6f58d7713f785a9eb6a5c (patch) | |
| tree | 3e4f42f93c7ae89a364e4d51fff6e5cec4e55fa9 /rushs/tinyprintf/freq_analysis/freq_analysis.c | |
add: graphs et rushs
Diffstat (limited to 'rushs/tinyprintf/freq_analysis/freq_analysis.c')
| -rw-r--r-- | rushs/tinyprintf/freq_analysis/freq_analysis.c | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/rushs/tinyprintf/freq_analysis/freq_analysis.c b/rushs/tinyprintf/freq_analysis/freq_analysis.c new file mode 100644 index 0000000..c60d7a6 --- /dev/null +++ b/rushs/tinyprintf/freq_analysis/freq_analysis.c @@ -0,0 +1,28 @@ +#include <stdio.h> + +int find_rank(int h[26], int min) +{ + int res = 0; + for (int i = 0; i < 26; i++) + { + res += h[i] > h[min] || (h[i] == h[min] && i < min); + } + return res; +} + +void freq_analysis(const char text[], const char table[]) +{ + int h[26] = { 0 }; + for (int i = 0; text[i]; i++) + { + h[text[i] - 'A']++; + } + + for (int j = 0; j < 26; j++) + { + if (h[j] != 0) + { + printf("%c %c\n", j + 'A', table[find_rank(h, j)]); + } + } +} |
