牛客练习赛7 E 珂朵莉的数列
思路:
树状数组+高精度
离散化不知道哪里写错了,一直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 珂朵莉的数列的更多相关文章
- 牛客练习赛7 E 珂朵莉的数列(树状数组+爆long long解决方法)
https://www.nowcoder.com/acm/contest/38/E 题意: 思路: 树状数组维护.从大佬那里学习了如何处理爆long long的方法. #include<iost ...
- 牛客练习赛9 F - 珂朵莉的约数
题目描述 珂朵莉给你一个长为n的序列,有m次查询 每次查询给两个数l,r 设s为区间[l,r]内所有数的乘积 求s的约数个数mod 1000000007 输入描述: 第一行两个正整数n,m第二行一个长 ...
- 牛客练习赛9 B - 珂朵莉的值域连续段
题目描述 珂朵莉给你一个有根树,求有多少个子树满足其内部节点编号在值域上连续 一些数在值域上连续的意思即其在值域上构成一个连续的区间 输入描述: 第一行有一个整数n,表示树的节点数.接下来n–1行,每 ...
- 牛客网 牛客练习赛7 D. 珂朵莉的无向图(多源BFS)
题目链接 Problem D 比赛的时候完全想不到 直接对给定的这些点做多源$BFS$,把给定的这些点全都压到队列里,然后一个个做. 最后统计被访问的点的个数即可. #include <bit ...
- 牛客练习赛7E 珂朵莉的数列
题意:求所有子区间的逆序数对数之和 题解:树状数组维护,对于每一对逆序数(l,r)属于l*(n-r+1)个区间,计算每一对对结果的贡献即可,可用树状数组维护,sum维护(n-r+1),按逆序数那样操作 ...
- 牛客网 牛客练习赛7 B.购物-STL(priority_queue)
B.购物 时间限制:C/C++ 1秒,其他语言2秒空间限制:C/C++ 32768K,其他语言65536K64bit IO Format: %lld 题目描述 在遥远的东方,有一家糖果专卖店 这家糖果 ...
- 牛客 40F 珂朵莉的约数 (莫队)
珂朵莉给你一个长为n的序列,有m次查询 每次查询给两个数l,r 设s为区间[l,r]内所有数的乘积 求s的约数个数mod 1000000007 直接莫队暴力维护复杂度是$O(8m\sqrt{m})$. ...
- [数据结构]ODT(珂朵莉树)实现及其应用,带图
[数据结构]ODT(珂朵莉树)实现及其应用,带图 本文只发布于博客园,其他地方若出现本文均是盗版 算法引入 需要一种这样的数据结构,需要支持区间的修改,区间不同值的分别操作. 一般的,我们会想到用线段 ...
- 【并查集缩点+tarjan无向图求桥】Where are you @牛客练习赛32 D
目录 [并查集缩点+tarjan无向图求桥]Where are you @牛客练习赛32 D PROBLEM SOLUTION CODE [并查集缩点+tarjan无向图求桥]Where are yo ...
随机推荐
- LINQ的左连接、右连接、内连接和Lamda表达式实现Left join
1.左连接: var LeftJoin = from t1 in l1join t2 in l2on t1.ID equals t2.ID into Joinedt12from t3 in Joine ...
- sql server删除重复数据,保留第一条
SELECT * FROM EnterpriseDataTools.Enterprise.CompanyMainwhere CompanyNo in (select CompanyNo from En ...
- 5Lambda表达式
C++11中的Lambda表达式用于定义并创建匿名的函数对象,以简化编程工作.首先看一下Lambda表达式的基本构成: [函数对象参数](操作符重载函数参数)mutable或exception -&g ...
- zw版【转发·台湾nvp系列Delphi例程】HALCON TestRegionPoint1
zw版[转发·台湾nvp系列Delphi例程]HALCON TestRegionPoint1 unit Unit1;interfaceuses Windows, Messages, SysUtils, ...
- LINUX环境变量(一)
Linux 的变量可分为两类:环境变量和本地变量 环境变量,或者称为全局变量,存在与所有的shell 中,在你登陆系统的时候就已经有了相应的系统定义的环境变量了.Linux 的环境变量具有继承性,即子 ...
- Hive中的三种不同的数据导出方式介绍
问题导读:1.导出本地文件系统和hdfs文件系统区别是什么?2.带有local命令是指导出本地还是hdfs文件系统?3.hive中,使用的insert与传统数据库insert的区别是什么?4.导出数据 ...
- Linux下实现 OpenSSL 简单加密与解密字符串
场景 shell脚本中存在明文密码 客户要求禁止使用明文密码,密码做加密处理. 方案 在网上了解到了Linux OpenSSL加密解密工具 可以指定各种加密算法为字符,文件做加密处理. 加密的案例比较 ...
- 手撕vue-cli配置——webpack.base.conf.js篇
在开始写webpack.base.conf.js(简称base)之前,我们先来看一下vue-loader.conf.js这个文件,毕竟在base中我们还会用到: 'use strict' //引入前一 ...
- Jsoup请求http或https返回json字符串工具类
Jsoup请求http或https返回json字符串工具类 所需要的jar包如下: jsoup-1.8.1.jar 依赖jar包如下: httpclient-4.5.4.jar; httpclient ...
- c++的class声明及相比java的更合理之处
或许是基于一直以来c/c++头文件声明和cXX实现物理上置于独立文件的考虑,c++中的OO在现实中基本上也是按照声明和实现分离的方式进行管理和编译,如下所示: Base.h #pragma once ...