C++ 如何检查c++;?

C++ 如何检查c++;?,c++,max,minimum,C++,Max,Minimum,您可以看到我的输入和输出: 在第一行中,3表示有多少行,5表示每行中有多少数据,之后我上传了数组。在输出中,我写入了行id、最小和最大数据。 我的任务是最小数据大于最大数据 for (int i = 0; i < n; i++) { if(t[i].min > t[i].max) { cout << t[i].id; } } for(int i=0;it[i].max) { 如果我

您可以看到我的输入和输出: 在第一行中,3表示有多少行,5表示每行中有多少数据,之后我上传了数组。在输出中,我写入了行id、最小和最大数据。 我的任务是最小数据大于最大数据

for (int i = 0; i < n; i++)
    {

        if(t[i].min > t[i].max)
        {
            cout << t[i].id;
        }
    }
for(int i=0;it[i].max)
{

如果我正确理解了这个问题,你需要像下面这样的东西

#include <iostream>
#include <utility>
#include <iterator>
#include <algorithm>

int main() 
{
    const size_t M = 3, N = 5;
    int a[M][N] =
    {
        { 10, 15, 12, 10, 10 },
        { 11, 11, 11, 11, 20 },
        { 18, 16, 16, 16, 20 }
    };

    std::pair<size_t, size_t> row = { 0, 0 };

    auto p = std::minmax_element( std::begin( a[0] ), std::end( a[0] ) );
    std::pair<int, int> minmax = { *p.first, *p.second };

    for ( size_t i = 1; !( minmax.second < minmax.first ) && ( i < M ); i++ )
    {
        auto p = std::minmax_element( std::begin( a[i] ), std::end( a[i] ) );

        if ( minmax.first < *p.first )
        {
            minmax.first = *p.first;
            row.first = i;
        }

        if ( *p.second < minmax.second )
        {
            minmax.second = *p.second;
            row.second = i;
        }
    }

    if ( minmax.second < minmax.first )
    {
        std::cout << "The minimum " << minmax.first
                  << " in the row " << row.first
                  << " is greater than the maximum " << minmax.second
                  << " in row " << row.second << '\n';
    }

    return 0;
}
或者在output语句中,可以使用表达式
row.first+1
row.second+1
获得如下输出

The minimum 16 in the row 3 is greater than the maximum 15 in row 1
如果程序过于复杂,无法满足您的知识水平,那么这里有一个简化的程序,它使用用户定义的函数minmax_元素。您需要知道的是标准类std::pair。它只是一个由两个元素组成的类,名称分别为
first
second

#include <iostream>
#include <utility>

std::pair<size_t, size_t> minmax_element( const int *a, size_t n )
{
    std::pair<size_t, size_t> minmax = { 0, 0 };

    for ( size_t i = 1; i < n; i++ )
    {
        if ( a[i] < a[minmax.first] ) minmax.first = i;
        else if ( a[minmax.second] < a[i] ) minmax.second = i;
    }

    return minmax;
}

int main() 
{
    const size_t M = 3, N = 5;
    int a[M][N] =
    {
        { 10, 15, 12, 10, 10 },
        { 11, 11, 11, 11, 20 },
        { 18, 16, 16, 16, 20 }
    };

    std::pair<size_t, size_t> row = { 0, 0 };

    auto minmax = minmax_element( a[0], N );

    for ( size_t i = 1; !( a[row.second][minmax.second] < a[row.first][minmax.first] ) && 
                        ( i < M ); i++ )
    {
        auto local_minmax = minmax_element( a[i], N );

        if ( a[row.first][minmax.first] < a[i][local_minmax.first] )
        {
            minmax.first = local_minmax.first;
            row.first = i;
        }

        if ( a[i][local_minmax.second] < a[row.second][minmax.second] )
        {
            minmax.second = local_minmax.second;
            row.second = i;
        }
    }

    if ( a[row.second][minmax.second] < a[row.first][minmax.first] )
    {
        std::cout << "The minimum " << a[row.first][minmax.first]
                  << " in the row " << row.first
                  << " is greater than the maximum " << a[row.second][minmax.second]
                  << " in row " << row.second << '\n';
    }

    return 0;
}
#包括
#包括
std::pair minmax_元素(常数int*a,大小n)
{
std::pair minmax={0,0};
对于(大小i=1;istd::cout嵌套循环?…如何?你怎么看?是的,它很好而且有效,但这段代码对我和我的老师来说太高了,有没有其他方法解决我的问题?@Awarestor因为它是在注释中编写的,你可以编写自己的函数,使用for循环在一行中查找最小值和最大值。
#include <iostream>
#include <utility>

std::pair<size_t, size_t> minmax_element( const int *a, size_t n )
{
    std::pair<size_t, size_t> minmax = { 0, 0 };

    for ( size_t i = 1; i < n; i++ )
    {
        if ( a[i] < a[minmax.first] ) minmax.first = i;
        else if ( a[minmax.second] < a[i] ) minmax.second = i;
    }

    return minmax;
}

int main() 
{
    const size_t M = 3, N = 5;
    int a[M][N] =
    {
        { 10, 15, 12, 10, 10 },
        { 11, 11, 11, 11, 20 },
        { 18, 16, 16, 16, 20 }
    };

    std::pair<size_t, size_t> row = { 0, 0 };

    auto minmax = minmax_element( a[0], N );

    for ( size_t i = 1; !( a[row.second][minmax.second] < a[row.first][minmax.first] ) && 
                        ( i < M ); i++ )
    {
        auto local_minmax = minmax_element( a[i], N );

        if ( a[row.first][minmax.first] < a[i][local_minmax.first] )
        {
            minmax.first = local_minmax.first;
            row.first = i;
        }

        if ( a[i][local_minmax.second] < a[row.second][minmax.second] )
        {
            minmax.second = local_minmax.second;
            row.second = i;
        }
    }

    if ( a[row.second][minmax.second] < a[row.first][minmax.first] )
    {
        std::cout << "The minimum " << a[row.first][minmax.first]
                  << " in the row " << row.first
                  << " is greater than the maximum " << a[row.second][minmax.second]
                  << " in row " << row.second << '\n';
    }

    return 0;
}