搞笑C++:1062:最高的分数

文章介绍了在C++中求解一组数中的最大值的三种方法,包括不使用数组,使用数组进行max比较,以及直接使用sort排序。通过对比,强调了高效函数在编程中的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目网址: 信息学奥赛一本通(C++版)在线评测系统 (ssoier.cn)

三种情况

我们老师以前给我们布置过一道题目,就是上面的题目,其实这道题我一拿到就想到了三种方法:

  1. 不用数组

  1. 用数组进行max排序

  1. max排序都不需要,直接sort排序

[1]不用数组

这种适合我那些还没有学到数组的小萌新们,具体是这样:

(说实话,我也想不出他们如何不用数组肝出来的,所以该代码来源于我的同学,有改动)

#include<bits/stdc++.h>
using namespace std;
int m,n,maxx = 0;
int main()
{
    cin >> n;
    for(int i = 1;i <= n;i++)
    {
        cin >> m;
        if(m > maxx)maxx = m;    
    }
    cout << maxx;
    return 0;
}

[2]用数组进行max排序

这大概是许多人都会想到的办法吧,实际上,这种方法不太好写,我给大家演示一下:

#include<bits/stdc++.h>
using namespace std;
int n,cj[110],maxx;
int main()
{
    cin >> n;
    for(int i = 1;i <= n;i++)cin >> cj[i];
    for(int i = 1;i <= n;i++)
    {
        maxx = max(maxx,cj[i]);
    }
    cout << maxx;
    return 0;
}

[3]max排序都不需要,直接sort排序

这种方法是最神的方法,直接使用sort排序,轻松解决:

#include<bits/stdc++.h>
using namespace std;
int n,cj[110];
int main()
{
    cin >> n;
    for(int i = 1;i <= n;i++)cin >> cj[i];
    sort(cj+1,cj+n+1);
    cout << cj[n];
    return 0;
}

总结

第三个代码11行直接结束,上面两个需要14行

所以说,还是需要高深的函数啊!

明天更新《C++编程基础》!!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值