题解 | #The Grand Tournament#

The Grand Tournament

https://ac.nowcoder.com/acm/contest/18713/A

两个数组 一个存原数组 一个存排序后的数组

用两个变量分别存数的和,相同时即可分为一组,即组内和相同 数相同

#include<bits/stdc++.h>
using namespace std;
#define eb emplace_back
#define mem(a, b) memset(a, b, sizeof(a))
#define DEBUG(x) cerr << #x << '=' << x << endl
#define repl(i,x,y) for(int i=x;i<=y; ++i)
#define repr(i,k,n) for(int i=x;i>=y; --i)
template <typename T>
inline void read(T& f){f = 0;T fu = 1;char c = getchar();while (c < '0' || c > '9'){if (c == '-'){fu = -1;}c = getchar();}while (c >= '0' && c <= '9'){f = (f << 3) + (f << 1) + (c & 15);c = getchar();}f *= fu;}
template <typename T>
void print(T x){if (x < 0) putchar('-'), x = -x;if (x < 10) putchar(x + 48);else print(x / 10), putchar(x % 10 + 48);}
template <typename T>
void print(T x, char t){print(x);putchar(t);}
typedef long long ll;
const int M = 1e9+7;
const int N = 1e6+100;
const int mod = 998244353;
const int maxn = 100;
int n, m, t,l,k,r,c;
int a[N],b[N];
signed main()
{
    read(n);
    int ans=0;
    for(int i=1;i<=n;i++)
    {
        read(a[i]);
        b[i]=a[i];
    }
    sort(b+1,b+1+n);
    ll sum1=0;
    ll sum2=0;
    for(int i=1;i<=n;i++)
    {
        sum1+=a[i];
        sum2+=b[i];
        if(sum1==sum2) ans++;
    }
    cout<<ans<<endl;
}
全部评论
???随便找个代码就说是20年沈阳A是把
点赞 回复 分享
发布于 2022-11-05 14:48 浙江

相关推荐

object3:开始给部分🌸孝子上人生第一课了
点赞 评论 收藏
分享
ProMonkey2024:5个oc?厉害! 但是有一个小问题:谁问你了?😡我的意思是,谁在意?我告诉你,根本没人问你,在我们之中0人问了你,我把所有问你的人都请来 party 了,到场人数是0个人,誰问你了?WHO ASKED?谁问汝矣?誰があなたに聞きましたか?누가 물어봤어?我爬上了珠穆朗玛峰也没找到谁问你了,我刚刚潜入了世界上最大的射电望远镜也没开到那个问你的人的盒,在找到谁问你之前我连癌症的解药都发明了出来,我开了最大距离渲染也没找到谁问你了我活在这个被辐射蹂躏了多年的破碎世界的坟墓里目睹全球核战争把人类文明毁灭也没见到谁问你了(别的帖子偷来的,现学现卖😋)
点赞 评论 收藏
分享
评论
9
收藏
分享
牛客网
牛客企业服务