HDU 5688:2016

网友投稿 888 2022-08-26

HDU 5688:2016

HDU 5688:2016

Problem D

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Total Submission(s): 247    Accepted Submission(s): 174

Problem Description

度熊所居住的 D 国,是一个完全尊重人权的国度。以至于这个国家的所有人命名自己的名字都非常奇怪。一个人的名字由若干个字符组成,同样的,这些字符的全排列的结果中的每一个字符串,也都是这个人的名字。例如,如果一个人名字是 ACM,那么 AMC, CAM, MAC, MCA, 等也都是这个人的名字。在这个国家中,没有两个名字相同的人。 度熊想统计这个国家的人口数量,请帮助度熊设计一个程序,用来统计每一个人在之前被统计过多少次。

Input

N,接下来的 N 行代表了  N 个名字。 N 不会超过 100,000,他们的名字不会超过40位.

Output

对于每输入的一个人名,输出一个整数,代表这个人之前被统计了多少次。

Sample Input

5 ACM MAC BBA ACM BAB

Sample Output

0 1 0 2 1

Source

这也是一道很水的题哎!对每一个输入的字符串排序,然后就可以用map做啦~

如果单纯的用cin输入会超时,默认情况,cin与stdin总是保持同步的,也就是说这两种方法可以混用,而不必担心文件指针混乱,同时cout和stdout也一样,两者混用不会输 出顺序错乱。正因为这个兼容性的特性,导致cin有许多额外的开销,如何禁用这个特性呢?只需一个语句 std::ios::sync_with_stdio(false);,这样就可以取消cin于stdin的同步了,此时的cin就与scanf差不多 了。

AC代码

#include #include#include#includeusing namespace std;#includemapk;int main(){ int N; char c[40]; cin>>N; getchar(); while(N--) { memset(c,0,sizeof(c)); gets(c); sort(c,c+strlen(c)); printf("%d\n",k[string(c)]); k[string(c)]++; } return 0;}

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Android反编译:smali语法(apk反编译后smali文件)
下一篇:SDUT 2416:Fruit Ninja II
相关文章

 发表评论

暂时没有评论,来抢沙发吧~