排列计算--题解

排列计算

http://www.nowcoder.com/questionTerminal/3c01283b486b40b1be29ea610247d4f5

根据题意可以推出在排列中将出现次数最多的地方放上最大的数,剩下的依次递减。要计算每个位置出现的位置,依据数据范围,暴力模拟会WA,简单差分一下就可以了。
代码如下:

#include<iostream>
#include<algorithm>
using namespace std;
int a[200010];
bool cmp(int a, int b)
{
    return a > b;
}
int main()
{
    int n, m;
    cin >> n >> m;
    while (m--)
    {
        int l, r;
        cin >>l >> r;
        a[l] += 1;
        a[r + 1] -= 1;

    }
    for (int i = 1;i <= n;i++)
        a[i] = a[i - 1] + a[i];
    sort(a + 1, a + 1 + n, cmp);
    long long int ans = 0,i=1;
    while (a[i])
    {
        ans += a[i] * (n + 1 - i);
        i++;
    }
    cout << ans << endl;
    return 0;
}

求牛币,QWQ。

全部评论

相关推荐

程序员小白条:你是沟通了900个,不是投了900份简历,你能投900份,意味着对面都要回复你900次,你早就找到实习了,没亮点就是这样的,别局限地区,时间投的也要早,现在都要7月了
点赞 评论 收藏
分享
Vincent777...:实习经历可以考虑放上去,对于软件使用方面可以细化一些,比如调整为:熟悉基于LSDYNA的瞬态动力学仿真分析,熟悉基于WORKBENCH的结构拓扑优化
我的简历长这样
点赞 评论 收藏
分享
评论
2
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务