C++数组——小鱼比可爱

题目描述

人比人,气死人;鱼比鱼,难死鱼。小鱼最近参加了一个“比可爱”比赛,比的是每只鱼的可爱程度。参赛的鱼被从左到右排成一排,头都朝向左边,然后每只鱼会得到一个整数数值,表示这只鱼的可爱程度,很显然整数越大,表示这只鱼越可爱,而且任意两只鱼的可爱程度可能一样。由于所有的鱼头都朝向左边,所以每只鱼只能看见在它左边的鱼的可爱程度,它们心里都在计算,在自己的眼力范围内有多少只鱼不如自己可爱呢。请你帮这些可爱但是鱼脑不够用的小鱼们计算一下。

输入格式

第一行输入一个整数 n,表示鱼的数目。

第二行内输入 n个整数,用空格间隔,依次表示从左到右每只小鱼的可爱程度。

输出格式

行内输出 n个整数,用空格间隔,依次表示每只小鱼眼中有多少只鱼不如自己可爱。

分析:

小鱼只能看到自己左边的数,使用for循环进行判断如果左边的数比自己小就加一。

#include<iostream>
using namespace std;
int main()
{
    int a[1000];
    int n;
    int sum;
    cin >> n;
    for (int i = 0; i < n; i++)
    {
        cin >> a[i];
    }
    for (int i = 0; i < n; i++)
    {
        sum = 0;
        for (int j = 0; j < i; j++)
        {
            if (a[j] < a[i])//如果比自己小就加一
            {
                sum++;
            }
 
        }
        cout << sum<<" ";
    }

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,那么你可以使用C++语言中的数组来比较元素大小。以下是一个简单的示例代码,可以帮助你比较整型数组中的元素大小: ```c++ #include <iostream> using namespace std; int main() { int arr[5] = {5, 2, 8, 4, 1}; // 声明一个包含5个整数的数组 int max_value = arr[0]; // 假设第一个元素最大 int min_value = arr[0]; // 假设第一个元素最小 int max_index = 0; // 最大元素的下标 int min_index = 0; // 最小元素的下标 // 遍历数组中的所有元素,找到最大值和最小值 for (int i = 1; i < 5; i++) { if (arr[i] > max_value) { max_value = arr[i]; max_index = i; } if (arr[i] < min_value) { min_value = arr[i]; min_index = i; } } cout << "数组中最大的元素是 " << max_value << ",索引为 " << max_index << endl; cout << "数组中最小的元素是 " << min_value << ",索引为 " << min_index << endl; return 0; } ``` 上述代码中,我们定义了一个包含5个整数的数组`arr`,然后使用for循环遍历数组,找到最大值和最小值。在循环中,我们使用两个变量`max_value`和`min_value`来分别记录当前已经找到的最大值和最小值,使用两个变量`max_index`和`min_index`来分别记录最大值和最小值对应的下标。最后,我们输出找到的最大值和最小值及其对应的下标。 如果你需要比较二维数组中的元素大小,可以使用类似的方法,只需在for循环中增加一重循环即可遍历数组中的每个元素。在判断大小时,你需要使用二维数组中的坐标来比较元素大小。以下是一个简单的示例代码,可以帮助你比较二维整型数组中的元素大小: ```c++ #include <iostream> using namespace std; int main() { int arr[3][3] = {{5, 2, 8}, {4, 1, 9}, {3, 7, 6}}; // 声明一个3x3的二维数组 int max_value = arr[0][0]; // 假设第一个元素最大 int min_value = arr[0][0]; // 假设第一个元素最小 int max_row = 0, max_col = 0; // 最大元素的行和列 int min_row = 0, min_col = 0; // 最小元素的行和列 // 遍历二维数组中的所有元素,找到最大值和最小值 for (int i = 0; i < 3; i++) { for (int j = 0; j < 3; j++) { if (arr[i][j] > max_value) { max_value = arr[i][j]; max_row = i; max_col = j; } if (arr[i][j] < min_value) { min_value = arr[i][j]; min_row = i; min_col = j; } } } cout << "二维数组中最大的元素是 " << max_value << ",坐标为 (" << max_row << ", " << max_col << ")" << endl; cout << "二维数组中最小的元素是 " << min_value << ",坐标为 (" << min_row << ", " << min_col << ")" << endl; return 0; } ``` 上述代码中,我们定义了一个3x3的二维数组`arr`,然后使用两重for循环遍历数组,找到最大值和最小值。在循环中,我们使用四个变量`max_value`、`min_value`、`max_row`和`max_col`分别记录当前已经找到的最大值、最小值以及它们对应的行和列。最后,我们输出找到的最大值和最小值及其对应的坐标。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值