Tanya and Postcard

CodeForces - 518B

有个小女孩决定给他的爸爸寄明信片。她已经想好了一句话(即长度为n的字符串s),包括大写和小写英文字母。但是他不会写字,所以她决定将报纸里的字母剪下来贴到明信片上,最好能够把字符串s拼凑出来。报纸里包含字符串t,包括大写和小写英文字母。我们知道,t的长度大于或等于串s的长度。
 
如果在s串中的某些位置上的字母能够在报纸串t中找到对应一模一样的字符,那么,她会高兴地喊“耶!”,如果在s串中的某些位置的字母只能在报纸串t中找到对应的字母(但是大小写对应不上),那么这个女孩说:“哎呦”。
 
现在,小女孩希望她喊“耶!”越多越好。在“耶!”一样多的情况下,她说:“哎呦”要尽量多。请你帮助来计算这两个的数量。
 
注意每个字母只能用一次。

Input

第一行包含串s(1≤|s| ≤2*10^ 5),由大写和小写英文字母组成。
 
第二行包含串t(|s|≤|t| ≤2*10^ 5),包括大写和小写英文字母, 即写在报纸上的文字。
 
这里|a| 表示字符串的长度。

Output

输出两个用空格隔开的非负整数:
 
第一个数字是小姑娘说“耶!”的次数。
第二个数字是小姑娘说“哎呦”的次数。

Sample Input

样例输入1:
AbC
DCbA
 
样例输入2:
ABC
abc
 
样例输入3:
abacaba
AbaCaBA

Sample Output

 
样例输出1:
3 0
 
样例输出2:
0 3
 
样例输出3:
3 4
 
sol:按题意暴力模拟,能说“耶!”就尽量说“耶!”,先做一遍说“耶!”,然后在搞另一个,O(n*2)
#include <bits/stdc++.h>
using namespace std;
typedef int ll;
inline ll read()
{
ll s=;
bool f=;
char ch=' ';
while(!isdigit(ch))
{
f|=(ch=='-'); ch=getchar();
}
while(isdigit(ch))
{
s=(s<<)+(s<<)+(ch^); ch=getchar();
}
return (f)?(-s):(s);
}
#define R(x) x=read()
inline void write(ll x)
{
if(x<)
{
putchar('-'); x=-x;
}
if(x<)
{
putchar(x+''); return;
}
write(x/);
putchar((x%)+'');
return;
}
#define W(x) write(x),putchar(' ')
#define Wl(x) write(x),putchar('\n')
const int N=;
int n,m;
char S[N],T[N];
map<char,int>Map;
bool Used[N];
int main()
{
int i,ans1=,ans2=;
scanf("%s",S+); n=strlen(S+);
scanf("%s",T+); m=strlen(T+);
Map.clear();
for(i=;i<=m;i++) Map[T[i]]++;
for(i=;i<=n;i++) if(Map[S[i]])
{
ans1++;
Used[i]=;
Map[S[i]]--;
}
for(i=;i<=n;i++) if(!Used[i])
{
if(islower(S[i]))
{
if(Map[S[i]-'a'+'A']) {ans2++; Map[S[i]-'a'+'A']--;}
}
else
{
if(Map[S[i]-'A'+'a']) {ans2++; Map[S[i]-'A'+'a']--;}
}
}
W(ans1); Wl(ans2);
return ;
}
/*
input
AbC
DCbA
output
3 0 input
ABC
abc
output
0 3 input
abacaba
AbaCaBA
output
3 4 input
zzzZZZ
ZZZzzZ
output
5 1
*/

codeforces518B的更多相关文章

随机推荐

  1. 简单的CSS圆形缩放动画

    简单的CSS圆形缩放动画 话不多说鼠标移动上去,看效果吧,效果预览 代码如下: <!DOCTYPE html> <html> <head> <title> ...

  2. Android学习之基础知识五—Android常用的七大控件

    一.TextView控件:在界面上显示一段文本信息 先看XML代码和执行效果:         代码分析: 1.android:id属性,给当前控件定义了一个唯一的标识符 2.android:layo ...

  3. SkylineGlobe 6.6 版本API更新

    TEPro6.6API更新 概述 API6.6 较6.5只做了微小的更新,您可以很容易的将6.5的应用程序移植为6.6版本的应用程序. C#环境中,修改步骤如下: 创建SGWorld66实例代替SGW ...

  4. Java多线程编程模式实战指南(三):Two-phase Termination模式

    停止线程是一个目标简单而实现却不那么简单的任务.首先,Java没有提供直接的API用于停止线程.此外,停止线程时还有一些额外的细节需要考虑,如待停止的线程处于阻塞(等待锁)或者等待状态(等待其它线程) ...

  5. Luogu4622 COCI2012-2013#6 JEDAN 组合、DP

    传送门 题意:给出一个$N$个数的序列$a_i$,其中$a_i=-1$表示第$i$个位置数字未知,问有多少种用非负整数代替$a_i$中$-1$的方法使得从全$0$序列经过以下操作若干次得到序列$a_i ...

  6. 把List<T>转换为DataTable

    下面这个学习,把List<T>转换为Datatable. 下面先创建一个对象T: class Ay { private int _ID; public int ID { get { ret ...

  7. 如何实现.net程序的进程注入

    原文:如何实现.net程序的进程注入   如何实现.net程序的进程注入                                   周银辉 进程注入比较常见,比如用IDE调试程序以及一些Sp ...

  8. OpenTK教程-2绘制一个三角形(正确的方式)

    上一个教程向我们展示了如何在屏幕上画一个三角形.但是,我说过,那是一种古老的方式,即使它能够正常运行,但是现在这已经不是"正确"的方式.上篇文章中我们将几何发送到GPU的方式是所谓 ...

  9. BugkuCTF web基础$_GET

    前言 写了这么久的web题,算是把它基础部分都刷完了一遍,以下的几天将持续更新BugkuCTF WEB部分的题解,为了不影响阅读,所以每道题的题解都以单独一篇文章的形式发表,感谢大家一直以来的支持和理 ...

  10. [朴智妍][Lullaby]

    歌词来源:http://music.163.com/#/song?id=484056971 作曲 : Bum/Sophiya/김용신 [作曲 : Bum/Sophiya/k/gi-myong-xin] ...