【题解】考分鄙视

题目描述

Whence这个学期考了n次试,每一次都有一个0-20000之间的整数分数。Whence本来的状态应该是每一次考试都比前一次多一分(除第一次),但由于他很不稳定,偏差可能很大。对于第i次考试,如果有第j次考试满足1≤j<i≤n,且以第j次考试分数作为基准估计的第i次考试成绩比实际成绩低,就说第i次考试鄙视了第j次考试(估计分可以超过20000)。为了提高自信,Whence想知道他这个学期所有考试总共有多少次鄙视。

输入格式

第一行,一个整数n(1<n≤100000);

第二行为n次考试成绩。

输出格式

一行,这个学期所有考试的总共鄙视次数(总数可能很大,只需要输出总数mod12345的值)。

输入样例

4

1 3 3 5

输出样例

3

题解

如果直接按照原数组求逆序貌似是有问题的。关键是我们是要比较估计值。

其实我们可以将每一个$a[i]$更改为其第$n$次考试的估计值,也就是让$a[i]$再加上$n - i$,再对新数组进行归并排序求逆序对即可。

#include <iostream>
#include <cstdio>

#define MAX_N 100000

using namespace std;

int n;
int a[MAX_N | 1];
long long ans;

void Merge_Sort(int lt, int rt)
{
    if(lt == rt) return;
    int mid = lt + rt >> 1;
    Merge_Sort(lt, mid);
    Merge_Sort(mid + 1, rt);
    int i = lt, j = mid + 1;
    int b[MAX_N | 1], cnt = 0;
    while(i <= mid && j <= rt)
    {
        if(a[i] >= a[j]) b[++cnt] = a[i++];
        else ans += mid - i + 1, b[++cnt] = a[j++];
    }
    while(i <= mid) b[++cnt] = a[i++];
    while(j <= rt) b[++cnt] = a[j++];
    for(register int i = lt; i <= rt; ++i)
    {
        a[i] = b[i - lt + 1];
    }
    return;
}

int main()
{
    scanf("%d", &n);
    for(register int i = 1; i <= n; ++i)
    {
        scanf("%d", &a[i]);
        a[i] += n - i; // 重点语句
    }
    Merge_Sort(1, n);
    printf("%lld", ans % 12345);
    return 0;
}

参考程序

原文地址:https://www.cnblogs.com/kcn999/p/11217359.html

时间: 2024-10-12 00:39:23

【题解】考分鄙视的相关文章

归并排序及应用

void merge_sort(int *s,int l,int h,int *t) //t辅助数组 { if(h-l>1){ int mid = l+(h-l)/2; int i=l,p=l,q=mid; merge_sort(s,l,mid,t); merge_sort(s,mid,h,t); while(p<mid||q<h){ if(q>=h||(p<mid&&s[p]<=s[q])) t[i++]=s[p++]; else t[i++]=s[q

8.10联考题解

早上起来莫名困,天天晚上十点睡为什么会困我也不是很懂--然后就迷迷瞪瞪做题,一直都不大清醒.因为一点智障的知识漏洞T3完全挂,然后T2炸内存T1做了两个多小时没做出来~但是也只能说明自己弱,好在现在发现这些坑总比联赛之后发现好得多吧. Evensgn 剪树枝 出题人:Vincent 时间限制:1s 空间限制:128MB 题目描述 繁华中学有一棵苹果树.苹果树有 n 个节点(也就是苹果),n ? 1 条边(也就是树枝).调皮的 Evensgn 爬到苹果树上.他发现这棵苹果树上的苹果有两种:一种是黑

洛谷 P1079 Vigen&#232;re 密码 题解

此文为博主原创题解,转载时请通知博主,并把原文链接放在正文醒目位置. 题目链接:https://www.luogu.org/problem/show?pid=1079 题目描述 16 世纪法国外交家 Blaise de Vigenère 设计了一种多表密码加密算法――Vigenère 密 码.Vigenère 密码的加密解密算法简单易用,且破译难度比较高,曾在美国南北战争中为 南军所广泛使用. 在密码学中,我们称需要加密的信息为明文,用 M 表示:称加密后的信息为密文,用 C 表示:而密钥是一种

8.8联考题解

今天的T1让我怀疑我是不是在做奥赛题--这考的是什么知识点啊这个,会不会用绝对值函数? Evensgn 的债务 时间限制: 1 Sec  内存限制: 128 MB 题目描述 Evensgn 有一群好朋友,他们经常互相借钱.假如说有三个好朋友A,B,C.A 欠 B 20 元,B 欠 C 20 元,总债务规模为 20+20=40 元.Evensgn 是个追求简约的人,他觉得这样的债务太繁杂了.他认为,上面的债务可以完全等价为 A 欠C20 元,B 既不欠别人,别人也不欠他.这样总债务规模就压缩到了 

POJ 2533 - Longest Ordered Subsequence(最长上升子序列) 题解

此文为博主原创题解,转载时请通知博主,并把原文链接放在正文醒目位置. 题目链接:http://poj.org/problem?id=2533 Description A numeric sequence of ai is ordered if a1 < a2 < ... < aN. Let the subsequence of the given numeric sequence (a1, a2, ..., aN) be any sequence (ai1, ai2, ..., aiK)

(leetcode题解)Pascal&#39;s Triangle

Pascal's Triangle  Given numRows, generate the first numRows of Pascal's triangle. For example, given numRows = 5,Return [ [1], [1,1], [1,2,1], [1,3,3,1], [1,4,6,4,1] ] 题意实现一个杨辉三角. 这道题只要注意了边界条件应该很好实现出来,C++实现如下 vector<vector<int>> generate(int

2017ZZUACM省赛选拔试题部分题解----谨以纪念我这卡线滚粗的美好经历

写在前面: 其实心里有些小小的不爽又有点小小的舒畅,为啥捏?不爽当然是因为没被选拔上啦,舒畅捏则是因为没被选拔上反而让自己警醒,学长也提点很多很多."沉下去,然后一战成名"学长如是对我说,我很开心.其实这完全算不算是题解,只是我个人的一些小想法而已.而且到现在还有一题不会...让自己长点记性吧. 题目 A :聪明的田鼠 Time Limit: 1 Sec Memory Limit: 128 MB Description 田鼠MIUMIU来到了一片农田,农田可以看成是一个M*N个方格的矩

LeetCode-001题解

此题目摘自LeetCode001 Given an array of integers, find two numbers such that they add up to a specific target number. The function twoSum should return indices of the two numbers such that they add up to the target, where index1 must be less than index2.

leetcode题解: Next Permutation

最近还一直在刷leetcode,当然,更多时候只是将题解写在自己的电脑上,没有分享出来.偶尔想起来的时候,就写出来. public class Solution { public void nextPermutation(int[] nums) { if(nums==null||nums.length<=1) return; nextPermutationHelp( nums,0,nums.length-1); } public void nextPermutationHelp(int []nu