GDKOI2015 Day2

P1

题目描述:

  给出一个二分图,选择互不相交的边,使得边覆盖的点权和最大。

solution:

  简单DP,用树状数组维护最大值。

  时间复杂度:$O(n \log n) $

P2

题目描述:

  给出N个或黑或白的元素,每个元素有与A集合和B集合相对应的A,B两个值,将N个元素分成A,B两个集合,使每个集合的前K大中的黑色元素的总和最大。

solution:

  因为每个元素都有两个关键字,而且每个关键字只对对应的集合有用,所以必须对其中一个关键字进行固定。枚举A集合的第K大是哪个元素(i),因为只需要黑色元素总和最大,所以A值比A[i]大的黑色元素都归到A集合,A值比A[i]小的白色元素也归到A集合(防止该元素是B集合的前K大)。然后对黑色元素和剩下的白色元素进行DP,状态f[p][q]表示到前p个元素有q个元素分到了A集合的最大值。

  时间复杂度:$ O(n^3) $

P3

题目描述:

  给定一棵树。在线求路径点序列u -> ... -> v1,连续子序列a1,a2 ... ak满足a1<a2< ... <aj>aj+1 >aj+2 >.....>ak或者a1>a2>... >aj< aj+1<aj+2<.... <ak,1<=j<=k,求最大的 \(k\)

solution:

  关于树的算法不多,这题LCA就可以了,只是如何实现合并而已,我们对于LCA的每个区间记12个域:

  区间左端:

  - 递增
  - 递减
  - 先增后减
  - 先减后增

  区间右端:
- 递增
- 递减
- 先增后减
- 先减后增
- 区间左端编号
- 区间右端编号
- 区间长度
- 最大值

  至于转移方程嘛……,自己推。

  时间复杂度:$ O(n \log n) $

P4

题目描述:

  给出一个一开始为0的无穷栈,每次从栈顶拿出一个数\(top\),并把栈里剩下的元素最低位变成$ (Y+1) \mod K \((Y为之前的最低位),然后用top与L相比,如果\) top < L \(,那么X减一,否则把\)top+AK\(复制K份放入栈中。当\)X=0$时,结束操作,输出top。

solution:

  这题的数据很大,因此应该是找规律的题目。观察可得,栈里面的数的变化只与出栈次数有关,如果要把栈里的某一个元素出栈,必须经历s次出栈,而( s%K=1).

  令$ L=cAK+d \(,而栈里的数i只可能是\) i=pAK+p,(0\leq p\leq c+1, 0\leq q\leq d) \(因此我们可以寻找循环节。例如\)K=5,L=21,A=2$

232218508336128.png

  这表格包含了所有可能的数字,从纵向来看,它代表某一个数加AK的值,横向来看,它代表每个数的变化。红色为死亡濒临线。对于第二行(从下向上数)的数来说,必须死13次才能将其出栈,对于第一行来说,必须要死135次才能将其出栈。如果要将第一行的全部出栈,必须死$ 135^2 $次。

再举一个例子:\(K=5,L=26,A=2\)

232219051456568.png

对于第三行要5次,第二行(5^2),第三行(5^3),……

再利用第一个例子研究答案:

30 31 32 33 34 * 31 32 33 34 30 * 22 23 24 *
31 32 33 34 30 * 22 23 24 * 30 31 32 33 34 *
22 23 24 * 30 31 32 33 34 * 31 32 33 34 30 *
23 24 * 30 31 32 33 34 * 31 32 33 34 30 * 22
24 * 30 31 32 33 34 * 31 32 33 34 30 * 22 2331 32 33 34 30 * 22 23 24 * 30 31 32 33 34 *
22 23 24 * 30 31 32 33 34 * 31 32 33 34 30 *
23 24 * 30 31 32 33 34 * 31 32 33 34 30 * 22
24 * 30 31 32 33 34 * 31 32 33 34 30 * 22 23
30 31 32 33 34 * 31 32 33 34 30 * 22 23 24 *22 23 24 * 30 31 32 33 34 * 31 32 33 34 30 *
23 24 * 30 31 32 33 34 * 31 32 33 34 30 * 22
24 * 30 31 32 33 34 * 31 32 33 34 30 * 22 23
30 31 32 33 34 * 31 32 33 34 30 * 22 23 24 *
31 32 33 34 30 * 22 23 24 * 30 31 32 33 34 *……

  规律显得,

  当d<K时,每行有( (d+1)K+(K-d-1) )个元素,每一部分为一行出栈的死亡情况,所以答案的循环节(即整个表格死一次)为( ((d+1)K+(K-d-1))K^c )

  算答案时令( t=(d+1)K+(K-d-1) ),把X拆成( X=a_{0}+\sum_{i=1}^{c}a_{i}tK^{i-1} ),通过( (\sum_{i=1}^{c}a_{i})%K )算出答案所在行,再利用( a_{0} )确定列。

  当d>=K时,每行有K个元素,所以答案的循环节为( K^(c+2) ),计算答案就想一想好了。

  废话不说(我也解释不清),上代码(和链接)

  wck

  lyl

#include <cstdio>
#include <algorithm>
#include <cmath>
#include <cstdlib>
#include <cstring>
#include <ctime>
#include <queue>
#include <deque>
#include <map>
#include <vector>
using namespace std;
typedef long long LL;
const LL oo=1e18;int T;
LL X, K, L, A;int main()
{freopen("avenger.in", "r", stdin);freopen("avenger.out", "w", stdout);scanf("%d", &T);while (T--){scanf("%I64d%I64d%I64d%I64d", &X, &K, &L, &A);LL AK=A*K;LL c=L/AK, d=L-AK*c;LL ans=0;if (d>=K-1){--X;for (int i=1; X && i<=c+2; X/=K, ++i)ans=(ans+X%K)%K;printf("%I64d\n", (c+1)*AK+ans);}else{LL t=(d+1)*K+(K-d-1);--X;LL a0=X%t;X/=t;for (int i=1; X && i<=c; X/=K, ++i)ans=(ans+X%K)%K;if (ans<d+1)//the last is in the front最后一行在前{if (a0<(d-ans+1)*K)//the last{LL tmp=a0%K;a0/=K;printf("%I64d\n", (c+1)*AK+(ans+a0+tmp)%K);}else//the last but one倒数第二行{a0-=(d+1-ans)*K;if (a0<K-1-d) printf("%I64d\n", c*AK+d+1+a0);else//the last最后一行{a0-=(K-1-d);printf("%I64d\n", (c+1)*AK+(a0%K+a0/K)%K);}}}else//the last but one is in the front倒数第二行在前{if (a0<(K-d-1)-(ans-d)+1)printf("%I64d\n", c*AK+a0+ans);else//the last最后一行{a0-=(K-d-1)-(ans-d)+1;if (a0<K*(d+1))printf("%I64d\n", (c+1)*AK+(a0/K+a0%K)%K);else//the last but one倒数第二行{a0-=K*(d+1);printf("%I64d\n", c*AK+d+1+a0);}}}}}return 0;
}

转载于:https://www.cnblogs.com/GerynOhenz/p/4361184.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/257511.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

写在SDOI2016Round1前的To Do List

理性的整理了一下自己的不足。 计算几何啥都不会&#xff0c;字符串类DP毫无练习&#xff0c;数据结构写的不熟&#xff0c;数论推不出式子&#xff0c;网络流建模常建残&#xff1b; 需要达成的任务&#xff1a; 一、网络流&#xff1a; 熟练网络流的板子&#xff08;之前一…

XMind入门教程

最近在总结一些框架知识的时候&#xff0c;总找不到一款好的软件来画流程图&#xff0c;后来在网上查找这方面的东西&#xff0c;找到了 XMind,发现用来画思维导图还挺好的&#xff0c;看起来思路清晰&#xff0c;美观。那么便将使用的一些经验分享给大家。 1、什么是思维导图&…

标签与表格

bgcolor 页面背景色 text 文字颜色 topmargain 上页边距 leftmargain 左页边距 rightmargain 右页边距 bottomargain 下页边距 background 背景壁纸 &nbsp 空…

java word转图片tiff_不怕复制内容 Word转存TIFF文件这么玩

辛辛苦苦把Word文件敲好&#xff0c;为了不让别人复制走内容&#xff0c;只能看文稿&#xff0c;有些人就选择转存成PDF文件——但是PDF文件依然可以被编辑&#xff0c;还有什么方法能防范呢&#xff1f;其实在Word 2003之前&#xff0c;用户可以通过Microsoft Office Document…

item-设置可见性

如果我们想要设置menu中item的可见行&#xff0c;有两种方式&#xff1a; 1.直接在menu的xml代码中设置 <menu> <item android:id"id/action_hotknot"android:showAsAction"always"android:icon"drawable/action_mode_hotknot"android:…

IDC:聚焦6+6,抓住数字化转型商机

今天&#xff0c;IDC中国2015年中国ICT市场趋势论坛巡回系列的第二站在北京举行。论坛的主题为“加速创新实现数字化转型”。 这是最坏的时代&#xff1a;经济增长乏力、实体经济不振、传统行业在被颠覆与重构、IT市场总体增长进入个位数区间、IT第二平台的领导厂商仍在困境中。…

编写EL函数

1.建立java类的静态函数 package chapter4;public class ELFun {public static String processStr(String s){s s.replaceAll("<", "&lt");s s.replaceAll(">", "&gt");s s.replaceAll(" ", " "…

2016.3.22(关系型数据库简介,管理数据库和表)

数据库的集中式控制有什么优点&#xff1f; 1&#xff1a;降低存储数据的冗余度 2&#xff1a;更高的数据一致性 3&#xff1a;存储数据的可以共享 4&#xff1a;可以建立数据库所遵循的标准 5&#xff1a;便于维护数据完整性 6&#xff1a;能够实现数据的安全性 存储数据有哪些…

java前端ajax提交数据_Java 前端使用Ajax通过FormData传递文件和表单数据到后台

提交1&#xff0c;当仅仅想上传文件到后台function tijiao(){var file $("#image")[0].files[0];//打印file 为对象console.log(file);var formObj new FormData();formObj.set(image, file);$.ajax({url:test/test3,data:formObj,type: POST,dataType:json,proces…

IBM收购以色列应用发现公司EZSource

6月1日晚消息&#xff0c;IBM宣布对以色列公司EZSource进行收购&#xff0c;交易的具体条款没有被披露。 EZSource成立于2003年&#xff0c;以自有视觉面板产品闻名&#xff0c;该公司的产品能够帮助开发人员将重要的大型机应用程序现代化。该公司在以色列、英国、美国、瑞士、…

oracle存储过程+游标处理select数据

create or replace PROCEDURE UPDATE_RECORDCODE iscursor location_data is select * from location where remark in(952701,9527008,952705);--申明游标serviceCode NUMBER:1; BEGINfor l in location_data loop --遍历游标BEGIN--业务处理UPDATE SERIAL_CODE SET CUR_NUMB…

POJ 3617 Best Cow Line(最佳奶牛队伍)

POJ 3617 Best Cow Line Time Limit: 1000MS  Memory Limit: 65536K 【Description】 【题目描述】 FJ is about to take his N (1 ≤ N ≤ 2,000) cows to the annual "Farmer of the Year" competition. In this contest every farmer arranges his cows in a …

js blob php_js发送blob数据, php端接收blob数据

服务器环境CentOs7.4 php7print_r($_FILES)blob结构如下Array([blob] > Array([name] > blob[type] > image/jpeg[tmp_name] > /tmp/phpu37qnN[error] > 0[size] > 1175745))很纳闷这个结构为什么没有图片数据流&#xff0c;只有图片的信息闷了几个小时胡…

eclipse环境配置、快捷键及基本操作

Eclipse与MyEclipse的区别 Elipse是一种可扩展的开放源代码的集成开发环境&#xff0c;具有免费、纯java语言编写、免安装、扩展性强等特点。 MyElipse在Elipse基础上追加的功能性插件&#xff0c;对插件收费&#xff0c;在WEB开发中提供强大的系统架构平台。 工作空间的基本配…

php 枚举类型比较,枚举的比较-python编程入门系列图文教程-PHP中文网教程

因为枚举成员不是有序的&#xff0c;所以它们只支持通过标识(identity) 和相等性 (equality) 进行比较。下面来看看 和 is 的使用&#xff1a;#!/usr/bin/env python3# -*- coding: UTF-8 -*-from enum import Enumclass User(Enum):Twowater 98Liangdianshui 30Tom 12Twow…

我与C++的不解情缘

我是一个老实人&#xff0c;我当时报考C真的全心是为了自己自考的免考&#xff0c;绝不是为了什么二级证&#xff0c;可是&#xff0c;进行到一半的时候&#xff0c;突然获悉&#xff0c;C自我们这次开始&#xff0c;不作为免考科目了&#xff0c;当时我的心里啊&#xff0c;那…

hadoop之 Hadoop2.2.0中HDFS的高可用性实现原理

在Hadoop2.0.0之前&#xff0c;NameNode(NN)在HDFS集群中存在单点故障&#xff08;single point of failure&#xff09;&#xff0c;每一个集群中存在一个NameNode&#xff0c;如果NN所在的机器出现了故障&#xff0c;那么将导致整个集群无法利用&#xff0c;直到NN重启或者在…

3D坦克大战游戏源码

3D坦克大战游戏源码&#xff0c;该游戏是基于xcode 4.3&#xff0c;ios sdk 5.1开发。在xcode4.3.3上完美无报错。兼容ios4.3-ios6.0 &#xff0c;一款ios平台上难得的3D坦克大战游戏源码&#xff0c;有20张不同的作战地图。通过左下角方向键和重力感应来控制坦克运行&#xff…

mongodb php 扩展 linux,CentOS Linux 安装PHP的MongoDB扩展

一、下载、编译以及安装MongoDB的php扩展cd /data0/softwaregit clone git://github.com/mongodb/mongo-php-drivercd mongo-php-drivergit submodule initgit submodule update/usr/local/webserver/php/bin/phpize./configure --with-php-config/usr/local/webserver/php/bin…

The hierarchy of the type UserOperateLogAdvisor is inconsistent

加入 aopalliance-1.0.jar转载于:https://www.cnblogs.com/toSeeMyDream/p/4375962.html