在C ++中查找序列的最小/最大/平均值

时间:2012-10-06 04:50:09

标签: c++ average max minimum

我正在创建一个模拟水库填充的程序。到目前为止,这个过程没有问题,除了我想要做的最后一件事,即抓住填充水库所需的最大,最小和平均年数。我想在不使用数组的情况下这样做。我想我很接近,但我必须错过一些简单的事情。请原谅我,我只是在学习C ++。

#include <iostream>
#include <cstdlib>
#include <cmath>
#include <string>
#include <ctime>

using namespace std;




int main ()
{

    string operation;
    do{
    cout << "Using the letters 's', or 'q', please indicate if you would like to run a simulation, or quit the program: " << endl;
    cin >> operation;
    } while (operation != "s" && operation != "q");
    string reservoir_name; // Creating variables for reservoir
    double reservoir_capacity;
    double outflow;
    double inflow_min;
    double inflow_max;

    if (operation == "q")
    {
        cout << endl;
        cout << "This was a triumph . . ." << endl;
        cout << "I'm making a note here: huge success!" << endl;
        system ("pause");
        return 0;
    }

    while (operation == "s") 
        {

                string reservoir_name; // Creating variables
                double reservoir_capacity;

                double inflow_min = 0;
                double inflow_max = 0;
                double inflow_average = inflow_min + inflow_max;
                double inflow_difference = inflow_max - inflow_min;
                double inflow_threshold = .9 * inflow_average/2; // Math for acceptable flow threshold.



                cout << "What is the name of the reservoir?" << endl;
                cin.ignore ();
                getline (cin,reservoir_name); // Grab whole string for reservoir name.
                cout << "What is the capacity of the reservoir in MAF (Millions of Acre Feet)?" << endl;
                cin >> reservoir_capacity;
                cout << "What is the minimum inflow?" << endl;
                cin >> inflow_min;
                cout << "What is the maximum inflow?" << endl;
                cin >> inflow_max;
                cout << "What is the required outflow?" << endl;
                cin >> outflow;
                cout << endl;
                inflow_average = inflow_min + inflow_max;
                inflow_threshold = .9 * inflow_average/2; // Calculate threshold for too much outflow.
                cin.ignore ();

                if (outflow > inflow_threshold) // Check for unacceptable outflow levels.
                {
                    cout << "Warning! The outflow is over 90% of the average inflow. Simulation aborted. Returning to main menu." << endl << endl;
                }
                else
                {
                    const int number_simulations = 10;
                    cout << endl;
                    cout << "Reservoir name: " << reservoir_name << endl;
                    cout << "Capacity of reservoir in MAF: " << reservoir_capacity << endl;
                    cout << "Maximum inflow in MAF: " << inflow_max << endl;
                    cout << "Minimum inflow in MAF: " << inflow_min << endl;
                    cout << "Required outflow in MAF: " << outflow << endl << endl;

                    cout << "Running simulation . . ." << endl << endl;
                    srand (time(0));
                    const int sentinel = -1;
                    int minimum = sentinel;
                    int maximum = sentinel;
                    int years_total;
                    for (int i = 1; i <= number_simulations; i++) // Loop should run the filling simulation 10 times.
                    {

                        int years = 0;
                        double fill_level = 0;
                        for (years; fill_level < reservoir_capacity; years++ ) // Loop should simulate filling reservoir using random inflow values between inflow_min and inflow_max.
                        {

                            double r = rand() * 1.0 / RAND_MAX;
                            double x = inflow_min + (inflow_max - inflow_min) * r;// SHOULD be between minimum inflow and maximum inflow.
                            // cout << "Random Number x :" << x << endl; WAS USED TO CHECK IF RANDOM NUMBER WAS CHANGING
                            fill_level = fill_level + x - outflow;
                            if (fill_level < 0)
                            {
                            fill_level = 0; // Prevent fill level from going negative.
                            }
                            //cout << "Fill level is " << fill_level << endl; TO CHECK THE CHANGE IN FILL LEVEL PER ITERATION
                            if (minimum == sentinel || years < minimum) // Trying to set up the method for retrieving minimum value here. Currently returning as 0.
                            {
                                minimum = years;
                            }
                            if (maximum == sentinel || years > maximum) // Trying to set up the method for retrieving maximum value here. Currently returning as 1 less than the actual maximum.
                            {
                                maximum = years;
                            }
                        }   // Simulate the change of water level.

                        cout << "Simulation " << i << ": The reservoir took " << years << " years to fill." << endl;

                    }

                        cout << "The minimum number of years needed to fill: " << minimum << endl;
                        cout << "The maximum number of years needed to fill: " << maximum << endl;
                        cout << "The average number of years needed to fill: " << years_total / 10 << endl; // Take the running total of years over 10 simulations and divide by 10. Currently returning as 0.
                }
                    cout << endl;
                    cout << "What would you like to do now?" << endl << endl; // Saving for later. The menu re-prompt message and code.
                    cout << "Using the letters 's', or 'q', please indicate if you would like to run a simulation or quit the program: " << endl;
                    cin >> operation;
                    if (operation == "q")
                    {
                        cout << endl;
                        cout << "This was a triumph . . ." << endl;
                        cout << "I'm making a note here: huge success!" << endl;
                        system ("pause");
                        return 0;
                    }
    }


    system ("pause");
    return 0;
}

2 个答案:

答案 0 :(得分:1)

由于我们讨论的是C ++,我觉得有必要提一下可以(大大)协助的标准C ++库操作:

  • std::minmax_element会返回一个包含集合的最小值和最大值的对(还有std::min_elementstd::max_element可用。)
  • std::accumulate,当用0初始化时,返回集合元素的总和;平均水平不远。

当然,如果您希望同时拥有3,这稍微不是最理想的,因为这意味着两次经过集合而不是一次。但是它仍然是O(N)时间和O(1)空间,并且会降低必须写的代码。

答案 1 :(得分:0)

您需要添加到years_total

years_total += years;

您需要将minimummaximum的设置移至外的 for循环。您可以使用不同的min和max设置取消sentinel。见下文:

#include <iostream>
#include <cstdlib>
#include <cmath>
#include <string>
#include <ctime>

using namespace std;

int main ()
{

    string operation;
    do{
    cout << "Using the letters 's', or 'q', please indicate if you would like to run a simulation, or quit the program: " << endl;
    cin >> operation;
    } while (operation != "s" && operation != "q");
    string reservoir_name; // Creating variables for reservoir
    double reservoir_capacity;
    double outflow;
    double inflow_min;
    double inflow_max;

    if (operation == "q")
    {
        cout << endl;
        cout << "This was a triumph . . ." << endl;
        cout << "I'm making a note here: huge success!" << endl;
        system ("pause");
        return 0;
    }

    while (operation == "s") 
        {

                string reservoir_name; // Creating variables
                double reservoir_capacity;

                double inflow_min = 0;
                double inflow_max = 0;
                double inflow_average = inflow_min + inflow_max;
                double inflow_difference = inflow_max - inflow_min;
                double inflow_threshold = .9 * inflow_average/2; // Math for acceptable flow threshold.



                cout << "What is the name of the reservoir?" << endl;
                cin.ignore ();
                getline (cin,reservoir_name); // Grab whole string for reservoir name.
                cout << "What is the capacity of the reservoir in MAF (Millions of Acre Feet)?" << endl;
                cin >> reservoir_capacity;
                cout << "What is the minimum inflow?" << endl;
                cin >> inflow_min;
                cout << "What is the maximum inflow?" << endl;
                cin >> inflow_max;
                cout << "What is the required outflow?" << endl;
                cin >> outflow;
                cout << endl;
                inflow_average = inflow_min + inflow_max;
                inflow_threshold = .9 * inflow_average/2; // Calculate threshold for too much outflow.
                cin.ignore ();

                if (outflow > inflow_threshold) // Check for unacceptable outflow levels.
                {
                    cout << "Warning! The outflow is over 90% of the average inflow. Simulation aborted. Returning to main menu." << endl << endl;
                }
                else
                {
                    const int number_simulations = 10;
                    cout << endl;
                    cout << "Reservoir name: " << reservoir_name << endl;
                    cout << "Capacity of reservoir in MAF: " << reservoir_capacity << endl;
                    cout << "Maximum inflow in MAF: " << inflow_max << endl;
                    cout << "Minimum inflow in MAF: " << inflow_min << endl;
                    cout << "Required outflow in MAF: " << outflow << endl << endl;

                    cout << "Running simulation . . ." << endl << endl;
                    srand (time(0));
                    int minimum = reservoir_capacity + 10;
                    int maximum = -1;
                    int years_total;
                    for (int i = 1; i <= number_simulations; i++) // Loop should run the filling simulation 10 times.
                    {

                        int years = 0;
                        double fill_level = 0;
                        for (years; fill_level < reservoir_capacity; years++ ) // Loop should simulate filling reservoir using random inflow values between inflow_min and inflow_max.
                        {

                            double r = rand() * 1.0 / RAND_MAX;
                            double x = inflow_min + (inflow_max - inflow_min) * r;// SHOULD be between minimum inflow and maximum inflow.
                            // cout << "Random Number x :" << x << endl; WAS USED TO CHECK IF RANDOM NUMBER WAS CHANGING
                            fill_level = fill_level + x - outflow;
                            if (fill_level < 0)
                            {
                                fill_level = 0; // Prevent fill level from going negative.
                            }
                            //cout << "Fill level is " << fill_level << endl; TO CHECK THE CHANGE IN FILL LEVEL PER ITERATION
                        }   // Simulate the change of water level.

                        if (years < minimum) // Trying to set up the method for retrieving minimum value here. Currently returning as 0.
                        {
                            minimum = years;
                        }
                        if (years > maximum) // Trying to set up the method for retrieving maximum value here. Currently returning as 1 less than the actual maximum.
                        {
                            maximum = years;
                        }
                        years_total += years;
                        cout << "Simulation " << i << ": The reservoir took " << years << " years to fill." << endl;

                    }

                        cout << "The minimum number of years needed to fill: " << minimum << endl;
                        cout << "The maximum number of years needed to fill: " << maximum << endl;
                        cout << "The average number of years needed to fill: " << years_total / 10 << endl; // Take the running total of years over 10 simulations and divide by 10. Currently returning as 0.
                }
                    cout << endl;
                    cout << "What would you like to do now?" << endl << endl; // Saving for later. The menu re-prompt message and code.
                    cout << "Using the letters 's', or 'q', please indicate if you would like to run a simulation or quit the program: " << endl;
                    cin >> operation;
                    if (operation == "q")
                    {
                        cout << endl;
                        cout << "This was a triumph . . ." << endl;
                        cout << "I'm making a note here: huge success!" << endl;
                        system ("pause");
                        return 0;
                    }
    }


    system ("pause");
    return 0;
}