C程序接受字符串输入并打印字符串中元音和重复次数最多的元音的数量

C program to accept a string input and print number of vowels and most repeated vowels in the string

我正在学习 C,所以我正在做不同的 C 编程挑战,其中之一就是这个程序。 WAP接受用户输入的字符串并打印号码。元音和字符串中重复次数最多的元音。

我能够计算并打印出元音的数量,但我无法弄清楚我应该如何计算字符串中重复次数最多的元音,尽管我可以直接在输出屏幕上打印出重复次数最多的元音只需在内部循环中使用 vowels[i] 的打印语句即可。但我想计算程序本身内部重复次数最多的元音,然后高效地打印出来。我尝试了不同的方法,但没有任何效果。另外,我想保持代码小而高效。有办法吗?

这是我目前所做的:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#define MAX 150

int main()
{
    char Statement[MAX];
    char vowels[] = {'a', 'e', 'i', 'o', 'u'};
    int i, j;

    puts("Enter a simple statement.");
    fgets(Statement, 150, stdin);
    printf("\nYou entered: %s\n", Statement);
    for(i=0; i<=strlen(Statement); i++){
        //Converting uppercase input to lowercase
        Statement[i] = tolower((unsigned char)Statement[i]);
    }
    //Calling the function to print no. of 
    NumberOfVowels(Statement, vowels); vowels

    return 0;
}

    int NumberOfVowels(char Statement[], char vowels[])
    {
        int i, j, vowelsAmount = 0, count = 0;
        for(i=0; i<5; i++){                             //outer loop

                for(j=0; j<=strlen(Statement); j++){    //inner loop
                if(vowels[i] == Statement[j]){
                vowelsAmount++;
                printf("%c - ", vowels[i]);
                }
            }
        }
        printf("\nTotal number of vowels = %d", vowelsAmount);
        return vowelsAmount;
    }

您可以尝试以下任何一种方法...

  • 创建结构 MAP,成员为 keyvalue。具有允许您填充 MAP 结构的辅助方法,其中 keyvowel,值为 no。 occurrences.
  • 创建一个元音二维数组,其中行代表 vowels,列号。 occurrences.
  • 最容易理解的是创建一个大小为 256 (ascii) 的数组,并在每次出现时将 array[ascii(vowel)] 处的值递增 1。

这是其中一个实现(我刚刚更新了你的代码,所以它很粗糙,请努力让它看起来更好,并删除多余的打印)

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#define MAX 150

    int NumberOfVowels(char Statement[], char vowels[], int counts[])
    {
        int i, j = 0;

        for(j=0; j<strlen(Statement); j++) {
            if (Statement[j] == '[=10=]' || Statement[j] == '\n') {
                continue;
            }
            for(i=0; i<5; i++) {
                if(vowels[i] == Statement[j]) {
                    int ascii = (int) vowels[i];
                    counts[ascii] = counts[ascii] + 1;
                }
            }
        }

        for(i=0; i<5; i++) {
            int ascii = (int) vowels[i];
            printf("%c - %d ", vowels[i], counts[ascii]);
        }
        printf("\n");
        return 0;
    }

int main()
{
    char Statement[MAX];
    char vowels[] = {'a', 'e', 'i', 'o', 'u'};
    int counts[256] = {0};
    int i, j;

    puts("Enter a simple statement.");
    fgets(Statement, 150, stdin);
    printf("\nYou entered: %s\n", Statement);
    for(i=0; i<=strlen(Statement); i++){
        //Converting uppercase input to lowercase
        Statement[i] = tolower((unsigned char)Statement[i]);
        printf("%c ", Statement[i]);
    }
    //Calling the function to print no. of 
    NumberOfVowels(Statement, vowels, counts);
    return 0;
}

样本运行

You entered: Hello How are you, I am fine!                                                                                                                           

h e l l o   h o w   a r e   y o u ,   i   a m   f i n e !    

  a - 2 e - 3 i - 2 o - 3 u - 1