hiho #1283 hiho密码

#1283 : hiho密码

时间限制:10000ms

单点时限:1000ms

内存限制:256MB

描述

小Ho根据最近在密码学课上学习到的知识,开发出了一款hiho密码,这款密码的秘钥是这样生成的:对于一种有N个字母的语言,选择一个长度为M的单词;将组成这个单词的所有字母按照顺序不重复的写出(即遇到相同字母时跳过);然后将字母表剩下的没有使用过的字母按照顺序在其后进行排列。

如对于有5个字母的hiho语,选择单词1, 2, 2, 4, 3(此处数字表示字母在字母表中的顺序),则秘钥为1,2,4,3,5。

但是有一天小Ho在计算出了秘钥之后,却发现他弄丢了一开始选择的单词,于是他找到了你,希望你能够帮他找到能够生成这个秘钥的最短的单词。

输入

每个输入文件包含单组测试数据。

每组测试数据的第一行为一个正整数N,意义如前文所述。

每组测试数据的第二行为N个正整数,用来描述一个秘钥,其中第i个正整数Ai表示秘钥的第i个字符在字母表中的顺序。

对于100%的数据,满足N<=1000,1<=Ai<=N。

对于100%的数据,满足对于任意1<=i, j<=N,若i≠j,则Ai≠Aj。

输出

对于每组测试数据,输出能够生成输入给出的秘钥的最短的单词(空串不认为是单词)。由于字母表没有给出,所以对于每个字母,输出其在字母表中的顺序即可(用空格隔开)。

样例输入
5
1 2 4 3 5
样例输出
1 2 4

解题思路:从后往前遍历,如果a[i-1]大于a[i],则i之前(包括i-1)都为密钥;

AC代码:
 1 #include "iostream"
 2 #define MAX 1000
 3
 4 using namespace std;
 5
 6 int main()
 7 {
 8     int n;
 9     int a[MAX];
10     cin >> n;
11
12     for (int i = 0; i < n; i++)
13         cin >> a[i];
14
15     int flag = 0;
16     for (int i = n - 1; i > 0; i--)
17     {
18         if (a[i - 1] > a[i])
19         {
20             flag = i - 1;
21             break;
22         }
23     }
24
25     for (int i = 0; i <= flag; i++)
26         cout << a[i] << " ";
27
28     return 0;
29
30 }

时间: 2024-09-30 15:18:56

hiho #1283 hiho密码的相关文章

hihocoder -1283 hiho密码(水题)

时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho根据最近在密码学课上学习到的知识,开发出了一款hiho密码,这款密码的秘钥是这样生成的:对于一种有N个字母的语言,选择一个长度为M的单词:将组成这个单词的所有字母按照顺序不重复的写出(即遇到相同字母时跳过):然后将字母表剩下的没有使用过的字母按照顺序在其后进行排列. 如对于有5个字母的hiho语,选择单词1, 2, 2, 4, 3(此处数字表示字母在字母表中的顺序),则秘钥为1,2,4,3,5. 但是有一天小Ho

【hiho】hiho第三十周&#183;二分图染色判定

是时候认真学学二分图了... 光会模板没用的,打好基础最重要~ 题目: 字面意思,二分图染色判断,判断是否是二分图 思路: 要让该无向图成为一张二分图,必须得将点划为G1,G2两个集合 也就是,对于给定的任何一条边,其连接的两个节点不能同色 那么我们可以总结出一个方法: 对于当前结点: 1.若其未被染色,我们规定将其染成A色,记为1 2.遍历其所有相邻的染色点,有未染色的,染为B色,记为2,DFS之 注:一旦被染色,说明此点状态被唯一确定 那么我们可以得到判断条件: 1.染色过程是否发生冲突 附

【hiho】hiho第二十九周&#183;扫雷I

题目描述: 大致是这样的,给你长度为n的序列,每个序列上的数代表半径为2的范围内有多少个地雷,问你至多能确定多少个位置的放置,并输出一定有雷的个数及位置序列.一定没有雷的个数及位置序列 思路: 题目数据范围不是很大,O(n)吧 第一个位置确定后,按照arr[1]来说,第二个位置也就确定了 同理,对于arr[2]来说,第三个位置也就确定了..... 但是还是WA了两次,因为他问的是一定确定的! 这里就有一种情况,第一个位置放雷和不放雷都可行,那么虽然满足,但是有些位置是不确定的! 所以flag1,

【hiho】hiho第三十一周&#183;二分图最大匹配,一些基础结论也会在此更新

题意: 二分图最大匹配 思路: 二分图最大匹配基础算法就是匈牙利算法,和网络流中的找增广路很类似 个人偏好DFS版本= = 当时也是看kuangbin大大的模板才逐渐摸索的 补充定义和定理: 最大匹配数:最大匹配的匹配边的数目最小点覆盖数:选取最少的点,使任意一条边至少有一个端点被选择最大独立数:选取最多的点,使任意所选两点均不相连最小路径覆盖数:对于一个 DAG(有向无环图),选取最少条路径,使得每个顶点属于且仅属于一条路径.路径长可以为 0(即单个点). 定理1:最大匹配数 = 最小点覆盖数

hihocoder 1566 皇室成员的名字

#1566 : 皇室成员的名字 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho正在学习世界历史.他发现历史上很多西方国家的皇室成员的名字都是由英文名字加罗马数字组成的,例如George IV(乔治四世).William IV(威廉四世).Elizabeth II(伊丽莎白二世)等. 为了更好的梳理历史脉络,小Ho决定写个程序把历史书上出现过的皇室名字排序:首先按英文名字的字典序排序,如果英文名字相同,再按罗马数字从小到大的顺序排序. 罗马数字表示可以参考 h

Hiho 1014 题目

hiho一下第二周 Hihocoder #1014 : Trie树 ? 参考链接:http://m.blog.csdn.net/blog/u012662688/38354777 ? Java实现: ? import java.io.BufferedInputStream; import java.util.Scanner; ? ? public class Main { ????public static void main(String[] args) {???????? ????????Sc

欧拉路径 提高篇 hiho第51周

题目链接:hiho 第51周 思路:首先特判n=1的情况,无输出.对于其他的按有向欧拉路径的求法把欧拉路径求出来以后,第一个按位全输出,接下来的的(2^n-1)个点,只需要输出二进制最后一位就可以了.详细的思路参考hiho 第51周 /************************************************************** Problem:hiho 第51周 User: youmi Language: C++ Result: Accepted Time:17m

[hiho 01]最长回文子串、Manacher算法

题目描述 - 基础方法:枚举子串,判断是否为回文串. - 改进:枚举中间位置,向两侧拓展. - 再改进:利用以前的信息,使得不用每个新位置都从长度1开始拓展. - 优化:将字符串预处理为奇数长度以避免考虑条件分支. - 再优化:开头加入特殊字符避免考虑边界. Manacher 算法: id 是中心点,mx 是其边界.P[i] 表示以 i 为中心的最长回文子串的折半长度. 只要 i < mx, 以 i 为中心的回文子串就可以不必从长度1开始找,而从min{P[j], mx - i}开始(其中j为i

hiho一下 第二十一周(线段树 离散化)

知识点1:离散化  对于这些区间来说,其实并不会在乎具体数值是多少,而是在他们的左右端点之间互相进行比较而已.所以你就把这N个区间的左右端点——2N个整数提出来,处理一下呗?你要注意的是,这2N个数是什么其实并不重要,你可以把这2N个数替换成为任何另外2N个数,只要他们之间的相对大小关系不发生改变就可以.” 解决方法: 那么我需要额外做的事情就是在构建线段树之前对区间进行预处理:将区间的左右端点选出来,组成一个集合,然后将这个集合依次对应到正整数集合上,并且利用这个对应将原来的区间的左右端点更换