简体   繁体   中英

Count how many times 5 appears in the vector

I have finished my program, and it runs perfectly fine, but i have one last question to ask. I need to count how many times the number 5 appears in my vector - disqualify. My code is below, and any help on how to determine how many times 5 appears as a disqualifying prime is greatly appreciated. I can only get the contents of the entire vector to appear so im at a loss. Thank you!

#include <iostream>
#include <iomanip>
#include <vector>
#include <iterator>
using namespace std;

int main()
{
    const int MAX(100);         // Number of primes to be identified
    long primes[MAX] = { 2, 3, 5 }; // Initialize with first three primes
    long trial(5);              // Hold a candidate prime
    int count(3);               // Count primes found - reflects initial values
    bool found(false);          // Indicates when a prime is found

    vector <long> nonPrimes; //Vector to hold non prime numbers
    vector <long> disqualify; //Vector to hold prime numbers that disqualify the non prime numbers as prime numbers. 
    vector<long>::iterator fives;//Vector iterator which will be used to find how many times the number 5 disqualifies a nonPrime number.

    do
    {
        trial += 2;               // Produce next candidate value
        found = false;            // Reset indicator - assume it is not prime

        for (int i = 0; i < count; i++)   // Try division by existing primes
        {
            found = (trial % primes[i]) == 0; // True if no remainder
            if (found) // No remainder means number is not a prime
                {
                nonPrimes.push_back(trial); // push_back trial values to vector nonPrimes
                disqualify.push_back(primes[i]); //push back disqualifying prime numbers to disqualify vector
                break;     // Terminate the division loop
                }
            }
        // The above loop will exit either due to a break or after trying all
        // existing primes as a divisor. found was initialized to false. If
        // found is false after exiting the loop, a divisor was not found.
        if (!found)               // We have a new prime: found = true! -- add numbers to vectors
            primes[count++] = trial;  // Save candidate in next array position
    } while (count < MAX);

    // Main loop has completed - we have found MAX prime numbers.
    // Display the prime numbers, presenting five numbers on one line.
    cout << "Prime numbers found during the program execution:" << endl;
    for (int i = 0; i < MAX; i++)
    {
        if (i % 5 == 0)          // For a new line on first line of output
            cout << endl;         // and on every fifth line that follows
        cout << setw(10) << primes[i];  // Provide space between numbers
    }
    cout << endl;              // All primes displayed - for a new line


    /*
        Display Non-primes and their disqualifiers
    */
    cout << "Non-Primes identified: " << count << endl; // Identify how many nonprimes appear and display the value.
    for (int i = 0; i < MAX; i++) //For loop to clarify position of output
    {
        if (i % 5 == 0)          // For a new line on first line of output
            cout << endl;         // and on every fifth line that follows
        cout << setw(10) << nonPrimes[i] << ":" << disqualify[i] << setw(10);   // outputs nonPrime numbers and their disqualifying primes
    }
    cout << endl;

    //Use iterator (fives) to produce how many times the digit 5 appears as a disqualifying prime number
    for (fives = disqualify.begin(); fives < disqualify.end(); fives++) // bounds checking for how many times 5 appears.
    {
            cout << "Numer of times 5 was a disqualifier: " << *fives << endl; // output number of times 5 appears as a disqualifying prime
    }
    system("Pause");

    return 0;
}

If I understand the question correctly, the last few lines are almost right.

//Use iterator (fives) to produce how many times the digit 5 appears as a disqualifying prime number
for (fives = disqualify.begin(); fives < disqualify.end(); fives++) // bounds checking for how many times 5 appears.
{
        cout << "Numer of times 5 was a disqualifier: " << *fives << endl; // output number of times 5 appears as a disqualifying prime
}

This loop says to run one-by-one through the elements of disqualify and print "Number of times 5 was a disqualifier: " followed by the element at that point in disqualify .

You can simply change that loop to count the fives by incrementing a counter every time it hits a 5, then put the print afterward like so (I changed the name of fives to ittr , a generic iterator name, to clear up confusion):

int five_count = 0;
vector<long>::iterator ittr;
for (ittr = disqualify.begin(); ittr < disqualify.end(); ittr++)
{
    if (*ittr == 5)
        ++five_count;
}
cout << "Number of times 5 was a disqualifier: " << five_count << endl;

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM