【CodeForces - 1051C 】Vasya and Multisets (模拟)

题干:

Vasya has a multiset ss consisting of nn integer numbers. Vasya calls some number xxnice if it appears in the multiset exactly once. For example, multiset {1,1,2,3,3,3,4}{1,1,2,3,3,3,4} contains nice numbers 22 and 44.

Vasya wants to split multiset ss into two multisets aa and bb (one of which may be empty) in such a way that the quantity of nice numbers in multiset aa would be the same as the quantity of nice numbers in multiset bb (the quantity of numbers to appear exactly once in multiset aa and the quantity of numbers to appear exactly once in multiset bb).

Input

The first line contains a single integer n (2≤n≤100)n (2≤n≤100).

The second line contains nn integers s1,s2,…sn (1≤si≤100)s1,s2,…sn (1≤si≤100) — the multiset ss.

Output

If there exists no split of ss to satisfy the given requirements, then print "NO" in the first line.

Otherwise print "YES" in the first line.

The second line should contain a string, consisting of nn characters. ii-th character should be equal to 'A' if the ii-th element of multiset ss goes to multiset aa and 'B' if if the ii-th element of multiset ss goes to multiset bb. Elements are numbered from 11to nn in the order they are given in the input.

If there exist multiple solutions, then print any of them.

Examples

Input

4
3 5 7 1

Output

YES
BABA

Input

3
3 5 1

Output

NO

解题报告:

   很简单的题意模拟题啊。。。搞WA了好几发、、还是码力不足啊、、写的好复杂、、

AC代码:

#include<cstdio>
#include<iostream>
#include<algorithm>
#include<queue>
#include<map>
#include<vector>
#include<set>
#include<string>
#include<cmath>
#include<cstring>
#define ll long long
#define pb push_back
#define pm make_pair
#define fi first
#define se second
using namespace std;
const int MAX = 2e5 + 5;
int bk[1005],qq[1005];
char opa[1005];
int a[1005],cnt;
int main()
{int n;cin>>n;for(int i = 1; i<=n; i++) {scanf("%d",a+i);bk[a[i]]++;}bool flag = 0;for(int i = 1; i<=n; i++) {if(bk[a[i]] == 2) opa[i]='A';else if(bk[a[i]] == 1) {cnt++;if(flag) opa[i]='A';else opa[i]='B';flag=!flag;}}if(cnt % 2 == 0) {puts("YES");for(int i = 1; i<=n; i++) {if(opa[i] !=0) putchar(opa[i]);else putchar('A');}return 0 ;}bool ok=0;for(int i = 1; i<=n; i++) {if(opa[i] == 0) {if(bk[a[i]] > 2) {if(flag) {opa[i] = 'A';for(int j = i+1; j<=n; j++) {if(a[j] == a[i]) opa[j] = 'B';}}else {opa[i] = 'B';for(int j = i+1; j<=n; j++) {if(a[j] == a[i]) opa[j] = 'A';}}ok=1;break;}}}if(ok==0) {puts("NO");return 0 ;}puts("YES");for(int i = 1; i<=n; i++) {if(opa[i]!=0) putchar(opa[i]);else putchar('A');}return 0 ;}
/*
12
1 2 3 4 5 5 6 6 6 7 9 11
YES
ABABAABAAABA
7
1 2 3 4 4 4 4
YES
ABABAAA
*/

 

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

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

相关文章

apache2+支持php7,Ubuntu14.04下配置PHP7.0+Apache2+Mysql5.7

Apache步骤一&#xff1a;安装apacheronyaoubuntu:~$ sudo apt install apache2安装好后&#xff0c;在浏览器上输入localhost(服务器端&#xff0c;请输入你的IP地址)&#xff0c;回车就会看到&#xff1a;PHP7.0步骤二&#xff1a;Ubuntu14.04下的默认源是PHP5.0&#xff0c;…

php怎么添加验证码,PHP添加验证码以及使用

现在很多页面在使用表单提交时&#xff0c;都会使用到验证码的使用、如何制做一个验证码呢&#xff1f;这里有一个用PHP的方法 以及代码1、首先在php.ini 配置文件里面把GD库打开 // 在php.ini里面找到 extensionphp_gd2.dll 把前面的分号删去。2、代码&#xff1a;<?php …

【CodeForces - 1051D】Bicolorings (dp,类似状压dp)

题干&#xff1a; You are given a grid, consisting of 22 rows and nn columns. Each cell of this grid should be colored either black or white. Two cells are considered neighbours if they have a common border and share the same color. Two cells AA and BB be…

oracle内存锁,Oracle OCP之硬解析在共享池中获取内存锁的过程

(1)在父游标的名柄没有找到SQL语句的文本&#xff1a;select * from gyj_t1 where id1;2、释放library cache Latch3、获得shared pool Latch(1)搜索FreeList 空闲Chunk(2)搜索LRU上可覆盖的chunk(3)搜索R-FreeList 空闲Chunk(4)如果没空间了&#xff0c;直接ORA-04031错误4、释…

【CodeForces - 214B】Hometask (模拟,有坑)

题干&#xff1a; Furik loves math lessons very much, so he doesnt attend them, unlike Rubik. But now Furik wants to get a good mark for math. For that Ms. Ivanova, his math teacher, gave him a new task. Furik solved the task immediately. Can you? You ar…

php 修改文件属性命令行,Linux_linux中如何通过命令修改文件属性,ls -l即可查看目录信息-rw - phpStudy...

linux中如何通过命令修改文件属性ls -l即可查看目录信息-rwxr-xr-x 1 xura xura 1753786 2010-05-09 09:54 Grad分别对应的是&#xff1a;文件属性 连接数 文件拥有者 所属群组 文件大小 文件修改时间 文件名例如&#xff1a;d   rwx   r-x  r-x第一个字符指定了文件类型。在…

【 HDU - 1796】How many integers can you find (容斥原理,二进制枚举或者dfs)

题干&#xff1a; Now you get a number N, and a M-integers set, you should find out how many integers which are small than N, that they can divided exactly by any integers in the set. For example, N12, and M-integer set is {2,3}, so there is another set {2,…

aix解锁oracle用户,aix用户被锁定的解决办法

原/etc/security/lastlog文件&#xff1a;oracle:time_last_login 1212750668tty_last_login /dev/pts/2host_last_login 10.126.10.200unsuccessful_login_count 18time_last_unsuccessful_login 1212750699tty_last_unsuccessful_login /dev/pts/2host_last_unsuccessf…

【CodeForces - 205B 】Little Elephant and Sorting (思维)

题干&#xff1a; The Little Elephant loves sortings. He has an array a consisting of n integers. Lets number the array elements from 1 to n, then the i-th element will be denoted as ai. The Little Elephant can make one move to choose an arbitrary pair of…

oracle外键有什么用,深入理解Oracle索引(20):外键是否应该加索引

先表明我的立场、我是绝对支持外键一定要加索引&#xff01;虽然在高版本的Oracle里、对这个要求有所降低、但依然有如下原因&#xff1a;① 死锁外键未加索引是导致死锁的最主要原因、因为无论更新父表主键、或者删除一个父表记录、都会在子表加一个表锁这就会不必要的锁定更多…

【CodeForces - 1027B 】Numbers on the Chessboard (没有营养的找规律题,无聊题)

题干&#xff1a; You are given a chessboard of size nnnn. It is filled with numbers from 11 to n2n2 in the following way: the first ⌈n22⌉⌈n22⌉ numbers from 11 to ⌈n22⌉⌈n22⌉ are written in the cells with even sum of coordinates from left to right f…

php mysql int 日期格式化 string,MYSQL int类型字段的时间存放和显示 和 php的时间存放函数...

mysql&#xff1a;int类型字段的时间存放UPDATE tablename SET add_time UNIX_TIMESTAMP(NOW())int类型字段的时间显示SELECT FROM_UNIXTIME(add_time) FROM tablenamephp时间戳函数&#xff1a;time() 获取当前时间戳 结果&#xff1a;1232553600strtotime() 转换为时间戳da…

【CodeForces - 1060C】Maximum Subrectangle (思维,预处理前缀和,dp,枚举长度)

题干&#xff1a; You are given two arrays aa and bb of positive integers, with length nn and mmrespectively. Let cc be an nmnm matrix, where ci,jai⋅bjci,jai⋅bj. You need to find a subrectangle of the matrix cc such that the sum of its elements is at m…

oracle按照指定顺序读取,oracle按照指定顺序进行排序

之前在网上查了下按照指定顺序进行排序的方法&#xff0c;根据charindex来处理排序&#xff0c;但是在oracle发现不行&#xff0c;因为oracle没有charindex函数&#xff0c;然后使用instr代替了charindex&#xff0c;然后又在网上搜了另外一种方实验如下&#xff1a;1.新建表CR…

【Codeforces 631C 】Report(单调栈,思维模拟)

题干&#xff1a; Each month Blake gets the report containing main economic indicators of the company "Blake Technologies". There are n commodities produced by the company. For each of them there is exactly one integer in the final report, that d…

oracle开放视图,Oracle视图

Oracle视图在Oracle中&#xff0c;视图是实际上并不存在的虚拟表。它存储在Oracle数据字典中&#xff0c;不存储任何数据。可以在调用时执行。通过连接一个或多个表的查询创建视图。Oracle创建视图句法&#xff1a;参数&#xff1a;view_name&#xff1a;它指定要创建的Oracle …

【CodeForces - 214C 】Game (拓扑排序,思维)

题干&#xff1a; Furik and Rubik love playing computer games. Furik has recently found a new game that greatly interested Rubik. The game consists of n parts and to complete each part a player may probably need to complete some other ones. We know that th…

php$this-conn可以不先定义吗,CodeIgniter 是不是支持PDO 查询?还是本来就不支持

CodeIgniter 是否支持PDO 查询&#xff1f;还是本来就不支持&#xff1f;本帖最后由 default7 于 2014-11-15 19:34:55 编辑配置CodeIgniter 的database 连接方式为PDO 类型&#xff0c;但是怎么都查询不到数据&#xff0c;却可以查处有多少记录&#xff01;自带代码仔细跟踪代…

【ZOJ - 2836 】Number Puzzle (容斥原理)

题干&#xff1a; Given a list of integers (A1, A2, ..., An), and a positive integer M, please find the number of positive integers that are not greater than M and dividable by any integer from the given list. Input The input contains several test cases. …

轮番滑动PHP,touch事件之滑动判断(左右上下方向)

touch事件之滑动判断(左右上下方向)作者: 2020.03.11 本文发布于18天前 分类:$("body").on("touchstart", function(e) {// 判断默认行为是否可以被禁用if (e.cancelable) {// 判断默认行为是否已经被禁用if (!e.defaultPrevented) {e.preventDefault();}}…