URAL 2080 Wallet 莫队算法
题目链接:Wallet
题意:给出n张卡片,k次使用。要求每次使用的卡片都在最上面。首先希望你合理的安排每张卡片的初始位置,并且输出。然后,问每次使用完卡片之后插入的位置上面有几张卡片,才能使得每次使用的卡片都在最上面。
思路:初始位置很容易得到。每次插入卡片时上面的卡片数,就是该卡片两次使用之间有多少个不同的数字。于是,问题变成:所有的两个相同数字之间有多少个不同的数字。
嗯..不分块会TLE的...乱用STL也会TLE的....
#include <stdio.h>
#include <string.h>
#include <iostream>
#include <map>
#include <vector>
#include <algorithm>
#include <math.h>
#define maxn 100010
using namespace std; int a[maxn];
int num[maxn];
int Ans, L, R;
int Init[maxn], cnt;
int n, k;
int los[maxn]; void getInit() {
bool vis[maxn];
memset(vis, 0, sizeof(vis));
int id = 0;
for (int i=1; i<=k; ++i) {
if (!vis[a[i]]) {
vis[a[i]]++;
Init[id++] = a[i];
}
}
for (int i=1; i<=n; ++i) {
if (!vis[i]) {
Init[id++] = i;
}
}
} struct Node {
int id;
int l, r;
}Query[maxn]; vector<int> pos[maxn];
int ans[maxn]; void init() {
memset(num, 0, sizeof(num));
Ans = 1, L = 1, R = 1;
cnt = 0;
for (int i=0; i<=n; ++i) {
pos[i].clear();
}
memset(ans, 0, sizeof(ans));
} void getQuery() {
for (int i=1; i<=k; ++i) {
pos[a[i]].push_back(i);
}
for (int i=1; i<=n; ++i) {
int len = pos[i].size();
if (len == 0) continue;
for (int j=0; j<len-1; ++j) {
Query[cnt].l = pos[i][j];
Query[cnt].r = pos[i][j+1];
Query[cnt].id = pos[i][j];
cnt++;
}
ans[pos[i][len-1]] = n-1;
}
} bool cmp(Node a, Node b) {
if (los[a.l] != los[b.l]) return a.l < b.l;
return a.r < b.r;
} void Del(int x) {
num[a[x]]--;
if (!num[a[x]]) {
Ans--;
}
} void Add(int x) {
if (!num[a[x]]) {
Ans++;
}
num[a[x]]++;
} int main() {
//freopen("in.cpp", "r", stdin);
while(~scanf("%d%d", &n, &k)) {
int kuai = (int)sqrt(k);
for (int i=1; i<=k; ++i) {
scanf("%d", &a[i]);
los[i] = i/kuai;
}
init();
getInit();
num[a[1]]++;
getQuery();
sort(Query, Query+cnt, cmp);
for (int i=0; i<cnt; ++i) {
//cout << Query[i].l << " " << Query[i].r << " " << L << " " << R << "#\n";
while(Query[i].l > L) {
Del(L);
L++;
}
while(Query[i].l < L) {
L--;
Add(L);
}
while(Query[i].r > R) {
R++;
Add(R);
}
while(Query[i].r < R) {
Del(R);
R--;
}
ans[Query[i].id] = Ans-1;
//cout << Ans << "@\n";
}
for (int i=0; i<n; ++i) {
if (i != 0) printf(" ");
printf("%d", Init[i]);
}
printf("\n");
for (int i=1; i<=k; ++i) {
printf("%d\n", ans[i]);
}
}
return 0;
}
URAL 2080 Wallet 莫队算法的更多相关文章
- NBUT 1457 莫队算法 离散化
Sona Time Limit:5000MS Memory Limit:65535KB 64bit IO Format: Submit Status Practice NBUT 145 ...
- BZOJ 2038: [2009国家集训队]小Z的袜子(hose) [莫队算法]【学习笔记】
2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec Memory Limit: 259 MBSubmit: 7687 Solved: 3516[Subm ...
- NPY and girls-HDU5145莫队算法
Time Limit: 8000/4000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Problem Description ...
- Codeforces617 E . XOR and Favorite Number(莫队算法)
XOR and Favorite Number time limit per test: 4 seconds memory limit per test: 256 megabytes input: s ...
- Bzoj 2038---[2009国家集训队]小Z的袜子(hose) 莫队算法
题目链接 http://www.lydsy.com/JudgeOnline/problem.php?id=2038 Description 作为一个生活散漫的人,小Z每天早上都要耗费很久从一堆五颜六色 ...
- 【BZOJ-3052】糖果公园 树上带修莫队算法
3052: [wc2013]糖果公园 Time Limit: 200 Sec Memory Limit: 512 MBSubmit: 883 Solved: 419[Submit][Status] ...
- 莫队算法 2038: [2009国家集训队]小Z的袜子(hose)
链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2038 2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 ...
- Codeforces 617E XOR and Favorite Number(莫队算法)
题目大概说给一个序列,多次询问区间异或和为k的连续子序列有多少个. 莫队算法,利用异或的性质,通过前缀和求区间和,先处理出序列各个前缀和,然后每次区间转移时维护i以及i-1前缀和为某数的个数并增加或减 ...
- 信心题--FUOJ2226(莫队算法)
http://acm.fzu.edu.cn/problem.php?pid=2226 信心题,还说是信心题,题目给的真好.但是一点都不像信心题. 又是一个新的算法,莫队算法 莫队算法是一个用数组就可以 ...
随机推荐
- 如何学习Python
[整理]如何学习Python + 如何有效利用Python有关的网络资源 + 如何利用Python自带手册(Python Manual) http://www.crifan.com/howto_lea ...
- js弹出对话框的方法总结
九种js弹出对话框的方法总结,需要的朋友可以参考一下 [1.最基本的js弹出对话框窗口代码] 这是最基本的js弹出对话框,其实代码就几句非常简单: <script LANGUAGE=" ...
- linux命令-sftp(模拟ftp服务)和scp(文件异地直接复制)
1)sftp sftp是模拟ftp的服务,使用22端口 针对远方服务器主机 (Server) 之行为 变换目录到 /etc/test 或其他目录 cd /etc/testcd PATH 列出目前所在目 ...
- Excel应该这么玩——2、命名列:消除地址引用
命名列:通过名称引用列,让公式更容易理解. 下面继续举上次的栗子. 1.历史遗留问题 之前虽然把数字编成了命名单元格,但其中还是有单元格地址B2.C2之类,要理解公式需要找到对应的列标题. 特别是像下 ...
- TextToSpeech之阅读文字
创建阅读类 /** * Created by RongGuang on 2014-11-21. * 中文朗读 */ public class ChineseToSpeech { private Tex ...
- [已解决] 点击 【Show in system explorer】Eclipse卡死,未响应
新版的Eclipse自带了 [Show in system explorer] 功能很方便,有一天突然不好用了,点它Eclipse就卡死, 可能由以下原因导致的: (可能性最大)windows本身有问 ...
- SUDTOJ 3323园艺问题 (线段树)
园艺问题 Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^ 题目描述 本巨养了一盆双色茉莉.这种花有一种特点:第i朵花在第Di天盛开,刚开时是紫色的 ...
- Spring RabbitMq
spring-rabbitmq.xml文件内容如下: <?xml version="1.0" encoding="UTF-8"?><beans ...
- Android监听应用程序安装和卸载
Android监听应用程序安装和卸载 第一. 新建监听类:BootReceiver继承BroadcastReceiver package com.rongfzh.yc; import android. ...
- php实战正则表达式:验证手机号
摘自http://www.tuicool.com/articles/MFNZRzu 本文通过逐步完善一个验证手机号的正则表达式来介绍了正则表达式中的 字符组 .量词 . 字符串起始/结束位置 . 分组 ...