12174 - Shuffle】的更多相关文章

You are listening to your music collection using the shuffle function to keep the music surprising. You assume that the shuffle algorithm of your music player makes a random permutation of the songs in the playlist and plays the songs in that order u…
用滑动窗口的思想,用一个数组保存每个数在窗口中出现的次数.再用一个变量记录在窗口中恰好出现一次的的数的个数,这样可以枚举所有可能的答案,判断它所对应的所有串口,当且仅当所有的串口均满足要求时这个答案可行. AC代码: #include <iostream> #include <cstdio> #include <cstdlib> #include <cctype> #include <cstring> #include <string>…
这道题能够用"滑动窗体"的思想来做,假想一个滑动的窗体,这个窗体的大小是s.划过一个大小为n的区域,可是由于s可能比n大,所以我们最好还是不去考虑s和n的大小,直接开出一个足够大的空间s+s+n.用ok[i]表示以i结尾的窗体是否符合要求. 假设最后结果ans == n + 1 .那么这个说明n<s且这n个数没有反复.所以终于答案为s 代码例如以下: #include<bits/stdc++.h> using namespace std; const int maxn…
https://vjudge.net/problem/UVA-12174 题意: 你在听音乐播放器,它采用随机播放形式.随机播放的原理时先随机产生一个1~n的排列,然后就按这个排列顺序播放歌曲.播放完这序列的所有歌曲以后,再次随机生成一个1-n的排列,再继续播放. 现在给你一个播放历史记录,这个历史记录是不完整的,以为它是开始记录时,已经有些歌曲播放过了而没有记录到. 现在给你一段从某个时刻开始的播放音乐的历史记录,以及播放器里一共有多少首歌. 问历史记录中第一首歌可能是某个随机列表中的第几首,…
题意:你正在使用的音乐播放器有一个所谓的乱序播放功能,即随机打乱歌曲的播放顺序.假设一共有s首歌, 则一开始会给这s首歌随机排序,全部播放完毕后再重新随机排序.继续播放,依次类推.注意,当s首歌播放完毕之前不会重新排序. 这样,播放记录里的每s首歌都是1~s的一个排列.给出一个长度为n的1≤s,n≤100000)的播放记录(不一定是从最开始记录的)xi(1≤xi≤s), 你的任务是统计下次随机排序所发生的时间有多少种有多少种可能性. 例如,s=4,播放记录是3,4,4,1,3,2,1,2,3,4…
题意:已知歌单中的歌曲数目s,和部分的播放历史,问下一首可能播放的歌曲种数. 分析: 1.按照歌单数目s,将播放历史划分为几部分. 2.将播放历史的n首歌曲之前加上s首歌曲,之后加上s首歌曲,为防止标号重复,分别将其标号为100001 + i和200001 + i. 3.枚举这个新的序列中的每首歌,以s首为区间,区间开头为i,结尾为s + i - 1,若该区间里的数字不唯一,则不可能以该区间为标准划分,排除i%s这一划分可能. 4.判断区间里歌曲唯一的方法,记录每首歌出现次数,进入区间则加1,离…
题意:假设一种音乐播放器有一个乱序的功能,设定每播放S首歌为一个周期,随机播放编号为1~S的歌曲.现在给一个长度为N的部分播放记录,请统计下次随机排序所发生的时间的可能性种数.(1≤S,N≤100000) 解法:由"连续的S个数"想到滑动窗口.O(n)循环一次,每次判断一个周期的[i-S+1,i]是否可行,记录入tf[i].最后O(n)枚举第一个"窗口"的初始结束位置来得到可能性种数. 实现:在N个数后另外添加S-1个与之前都互不相同的数,以补全最后几个数的周期.当…
首先预处理一下以每个数为结尾的前s个数是否能构成一个1~s的排列. 可以用cnt数组来记录每个数出现的次数和用一个变量记录一共有多少个不同的数出现. 然后枚举每种可能的情况,也就是枚举第一首歌会出现的位置,注意要考虑到不完整的序列. 代码不长,但是那个ok数组写起来有点蛋疼,因为要考虑到不完整序列的存在,改了好久才改对. #include <cstdio> #include <cstring> #include <cassert> + ; ]; ]; inline &a…
题目:题目链接 思路:见紫书,对具体操作方式还不是很理解,代码是从一个题解里看的,以后多回顾下,需要理解 代码: #include <iostream> #include <cstring> #include <set> using namespace std; ; int s, n, a[N], vis[N]; bool flag[N]; int ans; void init() { cin >> s >> n; ; ; i < n; i…
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 枚举第一段的范围[0..i] (0<=i<s) 然后看看[i+1..i+s-1],[i+s,i+s+s-1]..这些区间里面是不是每个区间,s个数字只各出现一次. 如果是的话则递增答案. 这里可以用尺取法.快速得到这些满足要求的s区间. 然后把相邻的区间用并查集并在一起. 即[i+1..i+s-1],[i+s,i+s+s-1]...这样的区间的话. 就把{i+1}{i+s}{i+s+s}...这些点并在同一个集合里面. 每次查…