1 今天干的俄罗斯的一场多校,被虐哭啊,就做出两题。
2
3
4
5
6
7

Gym 100496D Data Mining

8 题目讲得是给你一串数字,然后给你i,p,表示从第i开始,对这串数离散话,并且离散化后的字典序要最小,然后输出原来下标为i+p的离散化后的值
9 是多少。
10 假设i+p这个位置上的数为a。
11 如果在(i,i+p)这个范围内没有a,并且这个区间内没有重复的数,那么答案就是p
12 那么按照这个思路走,其实我们只要知道距离i位置最近的a的下标为r,那么其实我们只要知道(i,r)这个区间中有多少个不同的数n,那么答案就是
13 n+1。
14 因为数据比较大,所已对于每次的询问的复杂度必须做到O(1) , O(log(n)) 或 O(sqrt(n)).
15 就这道题而言用线段数O(logn)是可以的,进爷用默队算法O(sqrt(n))也做到了,我也想到了一种O(logn)的算法,蛋奶和,写不出来:
16 首先我们用RMQ预处理出每段区间的最大值,然后在询问的过程中我们便能用O(1)知道要求的区间的最大值R了,然后呢,用线段数去求R在这段区间按里是
17 第k大,然后k就是答案。(大家都觉得蛮有道理,但都懒得敲。。。)
18
19
20

Gym 100496H House of Representatives

22 题目告诉你n个城市的人口p[n],他们是构成了一棵树,在告诉你n-1条的路w[n],从一个城市v到u所需要的代价为p[v]*(u到v的距离).
23 然后我们要在n个城市里选出一个当首都,使其他所有城市到他的代价和最小。
24 欣爷一看就说是树形dp,然后就a掉了。
25 我们可以以编号为1的城市为根开始搜索,用o(n)的复杂度,得到一棵树,用d[u]来保存u这个节点的所有子节点到它的代价和,sum[u]来保存每棵子数
26 中总人口量。
27 这样一遍下来,其实我们就知道了以1号城市为首都的待价d[1],我们设dp[n]为n号城市当首都的代价,显然dp[1] = d[1] ;
28 然后如果你思路足够清晰的话可以得到这样一个递推式,设u为v的母亲,n个城市的总人数为all ,
29 那么dp[v] = d[v] +(all - sum[v])*(u到v的长度)+ dp[u] - d[v] - sum[v]*(u到v的长度) ;

 #include<stdio.h>
#include<vector>
#include<set>
#include<string.h>
#include<algorithm>
using namespace std;
typedef long long ll ;
const int M = + ;
int n , city[M] ;
vector<pair<int , int> > g[M] ;
ll d[M] , dp[M];
bool vis[M] ;
ll sum[M] ;
ll all ;
ll minn , id ; void tree (int u) {
for (int i = ; i < g[u].size () ; i ++) {
int v = g[u][i].first ;
if (vis[v]) continue ;
vis[v] = ;
dp[v] = (all - sum[v] ) * g[u][i].second + dp[u] - sum[v] * g[u][i].second ;
if (dp[v] < minn) {
minn = dp[v] ;
id = v ;
}
tree (v) ;
}
} void dfs (int u) {
for (int i = ; i < g[u].size () ; i ++) {
int v = g[u][i].first ;
if (vis[v] ) continue ;
vis[v] = ;
dfs (v) ;
d[u] += sum[v] * g[u][i].second + d[v] ;
sum[u] += sum[v] ;
}
} int main () {
freopen ("house.in" , "r" , stdin) ;
freopen ("house.out" , "w" , stdout) ;
scanf ("%d" , &n ) ;
for (int i = ; i < n ; i ++) {
scanf ("%d" , &city[i + ] ) ;
sum[i + ] = city[i + ] ;
all += sum[i + ] ;
}
for (int i = ; i < n - ; i ++) {
int u , v , w ;
scanf ("%d%d%d" , &u , &v , &w) ;
g[u].push_back (make_pair (v , w) ) ;
g[v].push_back (make_pair (u , w) ) ;
}
//printf ("g[0].size = %d\n" , g[0].size () ) ;
vis[] = ;
dfs ( ) ;
dp[] = d[] ;
minn = d[] ;
//for (int i = 1 ; i <= n ; i ++) printf ("d[%d] = %d , sum[%d] = %d\n" , i , d[i] , i , sum[i] ) ;
//printf ("d[0] = %d\n" , d[0] ) ;
memset (vis , , sizeof(vis)) ;
vis[] = ;
id = ;
tree ( ) ;
printf ("%I64d %I64d\n" , id , minn ) ;
return ;
}

30

r8 - ASC 41(俄罗斯多校)的更多相关文章

  1. oracle 小题

    create table student(sno varchar2(10) primary key,sname varchar2(20),sage number(2),ssex varchar2(5) ...

  2. 另一套Oracle SQL练习题,更新参考答案

    题干: create table student( sno ) primary key, sname ), sage ), ssex ) ); create table teacher( tno ) ...

  3. MySql练习+加源代码

    一.设有一个数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher). 四个表的结构分别如表1-1的表(一)~表(四)所示,数据如表1 ...

  4. SQL查询 练习题

    设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四个表的结构分别如表1-1的表(一)~表(四)所示,数据如表1-2的表 ...

  5. Oracle数据库作业-6 查询成绩比该课程平均成绩低的同学的成绩表

    33. 查询成绩比该课程平均成绩低的同学的成绩表. select * from score a where a.degree between 0 and( select avg(degree) fro ...

  6. 2014-11-9------- 设有一数据库,包括四个表:学生表(Student)、课程表(Course)、成绩表(Score)以及教师信息表(Teacher)。

    一.            设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四个表的结构分别如表1-1的表(一)~表( ...

  7. Extjs4学习

    1 Ext js初步 1.1 获取Extjs 下载extjs: 可以从http://extjs.org.cn/ 获得需要的extjs发布包及更多支持. 1.2 搭建学习环境: 假设您的机器已经安装my ...

  8. SQL整理3

    一.            设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四个表的结构分别如表1-1的表(一)~表( ...

  9. SQL查询语句联系

    建立四个表,分别是学生表,课程表,成绩表和教师信息表 插入信息: 题目: 1. 查询Student表中的所有记录的Sname.Ssex和Class列 select Sname,Ssex,Class f ...

随机推荐

  1. 远程连接RabbitMQ失败

    远程连接RabbitMQ失败 为了避免污染宿主系统环境,于是在虚拟机中搭建了一个linux环境并且按照了rabbitmq-server.然后在远程连接的时候一直连接失败. 官网上面给的例子都是在本地使 ...

  2. .net数据库操作

    刚接触到数据库时总是被数据库中的一些基本概念,比如Connection.Command.DataReader等,给整的糊里糊涂.如今,对数据库的基本操作有了一定的认识,特此做出总结,以便后续工作中查阅 ...

  3. UVa 437 The Tower of Babylon(经典动态规划)

    传送门 Description Perhaps you have heard of the legend of the Tower of Babylon. Nowadays many details ...

  4. js实现身份证号码验证

    /*根据[中华人民共和国国家标准 GB 11643-1999]中有关公民身份号码的规定,公民身份号码是特征组合码,由十七位数字本体码和一位数字校验码组成.排列顺序从左至右依次为:六位数字地址码,八位数 ...

  5. Python 培训之正则表达式

    re 模块 re.math 从头匹配 re.search 结构: re.math(r'^c',a)   不符合返回None 原字符: . 任意字符 [ ] 或者 [A-Z,a-z,b] \d 数字 \ ...

  6. DS18B20函数库建立实验

    1.主代码: /* 温度传感器  */#include "DS18B20.h"#include"def.h"u16 get_temp (void){    fl ...

  7. photobooth.js jquery

    <div id="example" class="photobooth" style="width:758px;height:400px&quo ...

  8. geoip scala api

    #!/bin/bash /home/hadoop/spark-1.6.2/bin/spark-shell --master spark://hbase11:7077 --executor-memory ...

  9. GLSL Debugger的姿势

    https://developer.apple.com/library/mac/documentation/GraphicsImaging/Conceptual/OpenGLShaderBuilder ...

  10. Javascript的匿名函数与自执行

    1.匿名函数 函数是JavaScript中最灵活的一种对象,这里只是讲解其匿名函数的用途.匿名函数:就是没有函数名的函数. 1.1 函数的定义,首先简单介绍一下函数的定义,大致可分为三种方式 第一种: ...