珂朵莉的数列

思路:

树状数组+高精度

离散化不知道哪里写错了,一直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. 深入浅出TCP之listen

    原文:http://blog.chinaunix.net/uid-29075379-id-3858844.html int listen(int fd, int backlog); 有几个概念需要在开 ...

  2. linux中vim的常用方法

    i 当前光标位置插入 a 当前光标后插入 0 另起一行插入 A 在光标所在行尾插入 I 在光标所在行首插入 :set nu设置 行号 :set nunu 取消行号 gg 到第一行 G 到最后一行 $ ...

  3. JSON—fastJSON

    FastJSON的简介和作用? 1:基于java实现的JSON解析器和生成器 2:将java对象序列化成JSON字符串 3:将JSON字符串反序列化得到java对象 (在服务端生成java是很麻烦的事 ...

  4. webstorm使用心得

    收藏夹功能:当工程目录很庞大时,有些子目录很经常打开,但层级又很深,这时候可以把目录添加到收藏夹里面,添加成功后,左侧有个“Favorites”菜单 面包屑导航:除了左侧的工程页面,可以选择目录之外, ...

  5. python 同时迭代多个序列

    每次分别从一个序列中取一个元素 >>> xpts = [1, 5, 4, 2, 10, 7] >>> ypts = [101, 78, 37, 15, 62, 99 ...

  6. linux常用命令:ip 命令

    ip命令是Linux下较新的功能强大的网络配置工具. 1.命令格式: ip  [OPTIONS]  OBJECT  [COMMAND [ARGUMENTS]] 2.命令功能: ip命令用来显示或操纵L ...

  7. Ubuntu系统下Jenkins的git构建基本方法

    上一博文讲到了本地脚本的构建方法. 本篇博文主要讲“Ubuntu系统下Jenkins的git构建基本方法”. 点击保存后即可完成简单的构建. 构建触发器 这个触发器是决定什么时候触发构建,可以设置为定 ...

  8. oracle中使用函数控制过程是否执行(结合job使用)

    oracle中使用函数控制过程是否执行(结合job使用时候,循环时间不好写的时候,可以此种方法比较方便) CREATE OR REPLACE FUNCTION wsbs_pk_date_validat ...

  9. selinux配置错误实例介绍

    错误原因 配置关闭SELinux,结果误操作 应修改配置文件/etc/selinux/config中的“SELINUX”参数的值, # SELINUX=enforcing  原始配置 SELINUX= ...

  10. java输出重定向

    Java的标准输入,输出分别是通过System.in和System.out来代表.默认情况下他们分别代表键盘和显示器. System类里提供了3个重定向标准输入,输出的方法. static void ...