珂朵莉的数列

思路:

树状数组+高精度

离散化不知道哪里写错了,一直wa,最后用二分写的离散化

哪位路过大神可以帮我看看原来的那个离散化错在哪里啊

通过代码:

import java.math.BigInteger;
import java.util.*;
import java.util.Scanner; class node
{
int x;
int id;
}
class cmp implements Comparator<node>
{
public int compare(node A,node B)
{
if(A.x<B.x)return -1;
else if(A.x==B.x)return 0;
else return 1;
}
}
public class Main{
public final static int N=(int)1e6+9;
public static int n;
public static int a[]=new int[N];
public static long b[]=new long[N];
public static long bit[]=new long[N];
public static long sum(int x)
{
long ret=0;
while(x>0)
{
ret+=bit[x];
x-=x&(-x);
}
return ret;
}
public static void add(int x,long a)
{
while(x<=n)
{
bit[x]+=a;
x+=x&(-x);
}
}
public static void main(String[] args) {
Scanner reader = new Scanner(System.in);
n=reader.nextInt();
for(int i=1;i<=n;i++)
{
a[i]=reader.nextInt();
b[i]=a[i];
}
Arrays.sort(b,1,n+1);
for(int i = 1; i <= n; i++) {
a[i] = Arrays.binarySearch(b, 1 ,n + 1,a[i]);
}
BigInteger ans=BigInteger.valueOf(0);
for(int i=1;i<=n;i++)
{
ans=ans.add(BigInteger.valueOf((sum(n)-sum(a[i]))*(n-i+1)));
add(a[i],i);
}
System.out.println(ans);
}
}

错误代码:

import java.math.BigInteger;
import java.util.*;
import java.util.Scanner; class node
{
int x;
int id;
}
class cmp implements Comparator<node>
{
public int compare(node A,node B)
{
if(A.x<B.x)return -1;
else if(A.x==B.x)return 0;
else return 1;
}
}
public class Main{
public final static int N=(int)1e6+9;
public static int n;
public static node a[]=new node[N];
public static int b[]=new int[N];
public static long bit[]=new long[N];
public static long sum(int x)
{
long ret=0;
while(x>0)
{
ret+=bit[x];
x-=x&(-x);
}
return ret;
}
public static void add(int x,long a)
{
while(x<=n)
{
bit[x]+=a;
x+=x&(-x);
}
}
public static void main(String[] args) {
Scanner reader = new Scanner(System.in);
n=reader.nextInt();
for(int i=1;i<=n;i++)
{
a[i]=new node();
a[i].x=reader.nextInt();
a[i].id=i;
}
//
Arrays.sort(a,1,n+1,new cmp()); int cnt=1;
a[0]=new node();
a[0].x=-1;
for(int i=1;i<=n;i++)
{
if(a[i].x!=a[i-1].x)b[a[i].id]=++cnt;
else b[a[i].id]=cnt;
}
//for(int i=1;i<=n;i++)System.out.println(b[i]);
BigInteger ans=BigInteger.valueOf(0);
for(int i=1;i<=n;i++)
{
ans=ans.add(BigInteger.valueOf((sum(cnt)-sum(b[i]))*(n-i+1)));
add(b[i],i);
}
System.out.println(ans);
}
}

牛客练习赛7 E 珂朵莉的数列的更多相关文章

  1. 牛客练习赛7 E 珂朵莉的数列(树状数组+爆long long解决方法)

    https://www.nowcoder.com/acm/contest/38/E 题意: 思路: 树状数组维护.从大佬那里学习了如何处理爆long long的方法. #include<iost ...

  2. 牛客练习赛9 F - 珂朵莉的约数

    题目描述 珂朵莉给你一个长为n的序列,有m次查询 每次查询给两个数l,r 设s为区间[l,r]内所有数的乘积 求s的约数个数mod 1000000007 输入描述: 第一行两个正整数n,m第二行一个长 ...

  3. 牛客练习赛9 B - 珂朵莉的值域连续段

    题目描述 珂朵莉给你一个有根树,求有多少个子树满足其内部节点编号在值域上连续 一些数在值域上连续的意思即其在值域上构成一个连续的区间 输入描述: 第一行有一个整数n,表示树的节点数.接下来n–1行,每 ...

  4. 牛客网 牛客练习赛7 D. 珂朵莉的无向图(多源BFS)

    题目链接  Problem D 比赛的时候完全想不到 直接对给定的这些点做多源$BFS$,把给定的这些点全都压到队列里,然后一个个做. 最后统计被访问的点的个数即可. #include <bit ...

  5. 牛客练习赛7E 珂朵莉的数列

    题意:求所有子区间的逆序数对数之和 题解:树状数组维护,对于每一对逆序数(l,r)属于l*(n-r+1)个区间,计算每一对对结果的贡献即可,可用树状数组维护,sum维护(n-r+1),按逆序数那样操作 ...

  6. 牛客网 牛客练习赛7 B.购物-STL(priority_queue)

    B.购物 时间限制:C/C++ 1秒,其他语言2秒空间限制:C/C++ 32768K,其他语言65536K64bit IO Format: %lld 题目描述 在遥远的东方,有一家糖果专卖店 这家糖果 ...

  7. 牛客 40F 珂朵莉的约数 (莫队)

    珂朵莉给你一个长为n的序列,有m次查询 每次查询给两个数l,r 设s为区间[l,r]内所有数的乘积 求s的约数个数mod 1000000007 直接莫队暴力维护复杂度是$O(8m\sqrt{m})$. ...

  8. [数据结构]ODT(珂朵莉树)实现及其应用,带图

    [数据结构]ODT(珂朵莉树)实现及其应用,带图 本文只发布于博客园,其他地方若出现本文均是盗版 算法引入 需要一种这样的数据结构,需要支持区间的修改,区间不同值的分别操作. 一般的,我们会想到用线段 ...

  9. 【并查集缩点+tarjan无向图求桥】Where are you @牛客练习赛32 D

    目录 [并查集缩点+tarjan无向图求桥]Where are you @牛客练习赛32 D PROBLEM SOLUTION CODE [并查集缩点+tarjan无向图求桥]Where are yo ...

随机推荐

  1. Summary: Stack Overflow Error

    What is a stack overflow error? Parameters and local variables are allocated on the stack (with refe ...

  2. Echarts使用及动态加载图表数据 折线图X轴数据动态加载

    Echarts简介 echarts,缩写来自Enterprise Charts,商业级数据图表,一个纯JavaScript的图表库,来自百度...我想应该够简洁了 使用Echarts 目前,就官网的文 ...

  3. sql 中延时操作

    select 1; WAITFOR DELAY '00:00:30'; select 2; --执行完第一个之后会 延时 30秒,才会执行第二个sql

  4. HDU 4770

    这题说的是一在一个N*M的房间内,然后有些房间不能被灯光照亮,有一个灯可以转动方向,其他的灯只能在固定一个方向上,因为数据比较小,所以比较水,直接暴力的进行枚举就好了,但是还是 wa了很久,原因没认真 ...

  5. Hive四种数据导入方式介绍

    问题导读 1.从本地文件系统中通过什么命令可导入数据到Hive表? 2.什么是动态分区插入? 3.该如何实现动态分区插入? 扩展: 这里可以和Hive中的三种不同的数据导出方式介绍进行对比? Hive ...

  6. Java代码质量度量工具大阅兵

    FindBugs FindBugs, a program which uses static analysis to look for bugs in Java code. It is free so ...

  7. QQ群免IDKEY加群PHP源码

    加群链接需要idkey的,该源码自动解析idkey,实现免idkey加群. 该源码来自彩虹秒赞系统. 例如:api.yum6.cn/qqun.php?qun=463631294 <?php /* ...

  8. 06: Django Admin

    目录:Django其他篇 01:Django基础篇 02:Django进阶篇 03:Django数据库操作--->Model 04: Form 验证用户数据 & 生成html 05:Mo ...

  9. 20145118 《Java程序设计》第6周学习总结

    20145118 <Java程序设计>第6周学习总结 教材学习内容总结 1.数据依靠串流在目的地与来源地之间传输,无论来去如何,只要取得InputStream或OutputStream的实 ...

  10. 20145314郑凯杰《网络对抗技术》实验9 web安全基础实践

    20145314郑凯杰<网络对抗技术>实验9 web安全基础实践 一.实验准备 1.0 实验目标和内容 Web前端HTML.能正常安装.启停Apache.理解HTML,理解表单,理解GET ...