珂朵莉的数列

思路:

树状数组+高精度

离散化不知道哪里写错了,一直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. svg绘图工具raphael.js的使用

    1.raphael.js svg画图的开源库,支持IE8+ 官方api: http://dmitrybaranovskiy.github.io/raphael/reference.html Githu ...

  2. Twitter OA prepare: Visit element of the array

    分析:就是建立一个boolean array来记录array里面每个元素的访问情况,遇到访问过的元素就停止visiting,返回未访问的结点个数 public int visiting(int[] A ...

  3. APB总线

    APB(Advance Peripheral Bus)是AMBA总线的一部分,从1998年第一版至今共有3个版本. AMBA 2 APB Specfication:定义最基本的信号interface, ...

  4. 无法在web服务器下启动调试。该Web服务器未及时响应

    下午在运行项目的时候,突然出现了以下错误: 无法在web服务器上启动调试.该Web服务器未及时响应.可能是因为另一个调试器已连接到该Web服务器. 搜索了很久才找到这个解决方案: 1:Web.conf ...

  5. Java线程基础知识(状态、共享与协作)

    1.基础概念 CPU核心数和线程数的关系 核心数:线程数=1:1 ;使用了超线程技术后---> 1:2 CPU时间片轮转机制 又称RR调度,会导致上下文切换 什么是进程和线程 进程:程序运行资源 ...

  6. 本地缓存之GUAVA

    项目开发中,很多配置数据需要缓存,一般来说,开发人员都会手动写HashMap,HashSet或者ConcurrentHashMap,ConcurrentHashSet缓存数据,但是这样的缓存往往存在内 ...

  7. 1.hive开窗函数,分析函数

    http://yugouai.iteye.com/blog/1908121 分析函数用于计算基于组的某种聚合值,它和聚合函数的不同之处是:对于每个组返回多行,而聚合函数对于每个组只返回一行.开窗函数指 ...

  8. MATLAB 简明教程

    MATAB 是我学习和接触的第一种工具类的编程语言,最早可以追溯到大一上数学分析这门课的时候.MATLAB既是一种软件也是一门编程语言,MATLAB功能强大在理科和工科中运用较多. MATLAB 是 ...

  9. 数据仓库基础(十)Informatica 组件1

    本文转载自:http://www.cnblogs.com/evencao/p/informatica.html Informatica主要的组件: Source Qualifier 从数据源读取数据 ...

  10. ping和telnet的区别

    内容主要转自: http://jingyan.baidu.com/article/8065f87fc3b31123312498e5.html http://zhidao.baidu.com/link? ...