Count number of occurrences of a digit within a string

后端 未结 2 1694
遥遥无期
遥遥无期 2021-01-24 04:23

So I\'m trying to count the number of occurrences of each digit within an array.

My code I\'ve got so far looks like the following:

#include 

        
相关标签:
2条回答
  • 2021-01-24 04:55

    Consider this modified code:

    #include <stdio.h>
    #include <string.h>
    
    int main()
    {
      int numbers [10]= {1, 4, 5, 5, 5, 6, 6, 3, 2, 1};
      int count = 0;
    
      for(int i = 0; i < 10; i++) { //i = current digit
        for (int j = 0; j < 10; j++) { //j = index in array
          if (i == numbers[j]) {
            count++;
          }
        }
        printf("Number %d has occured %d times \n", i, count);
        count = 0;
      }
    }
    

    Output:

    Number 0 has occured 0 times 
    Number 1 has occured 2 times 
    Number 2 has occured 1 times 
    Number 3 has occured 1 times 
    Number 4 has occured 1 times 
    Number 5 has occured 3 times 
    Number 6 has occured 2 times 
    Number 7 has occured 0 times 
    Number 8 has occured 0 times 
    Number 9 has occured 0 times 
    

    You were counting how often each digit occuring in the array (including duplicate digits in the array) occured.

    0 讨论(0)
  • 2021-01-24 05:06

    You are going to need to arrays - one for the count (result) and one for the input. You should increment the index in the count array as you loop over the input numbers. I couldn't resist actually writing the code so, here you go, the following should work IN C++

    #include <stdio.h>
    #include <string.h>
    
    int main()
    {
      int inputNumbers [] = {1, 4, 5, 5, 5, 6, 6, 3, 2, 1};
      int resultCount [] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
      int countNumbers = sizeof(inputNumbers) / sizeof(inputNumbers[0]);
    
      for(int i = 0; i < countNumbers; i++)
      {
         resultCount[inputNumbers[i]]++;
      }
    
      for(int i = 0; i < countNumbers; i++)
      {
        printf("Number %d has occured %d times \n", i, resultCount[i]);
      }
    }
    

    Hope that helps.

    0 讨论(0)
提交回复
热议问题