博客
关于我
W2 - Ananagrams
阅读量:692 次
发布时间:2019-03-15

本文共 3042 字,大约阅读时间需要 10 分钟。

题目描述

Most crossword puzzle fans are used to anagrams — groups of words with the same letters in different

orders — for example OPTS, SPOT, STOP, POTS and POST. Some words however do not have this
attribute, no matter how you rearrange their letters, you cannot form another word. Such words are
called ananagrams, an example is QUIZ.
Obviously such definitions depend on the domain within which we are working; you might think
that ATHENE is an ananagram, whereas any chemist would quickly produce ETHANE. One possible
domain would be the entire English language, but this could lead to some problems. One could restrict
the domain to, say, Music, in which case SCALE becomes a relative ananagram (LACES is not in the
same domain) but NOTE is not since it can produce TONE.
Write a program that will read in the dictionary of a restricted domain and determine the relative
ananagrams. Note that single letter words are, ipso facto, relative ananagrams since they cannot be
“rearranged” at all. The dictionary will contain no more than 1000 words.

Input

Input will consist of a series of lines. No line will be more than 80 characters long, but may contain any

number of words. Words consist of up to 20 upper and/or lower case letters, and will not be broken
across lines. Spaces may appear freely around words, and at least one space separates multiple words
on the same line. Note that words that contain the same letters but of differing case are considered to
be anagrams of each other, thus ‘tIeD’ and ‘EdiT’ are anagrams. The file will be terminated by a line
consisting of a single ‘#’.

Output

Output will consist of a series of lines. Each line will consist of a single word that is a relative ananagram

in the input dictionary. Words must be output in lexicographic (case-sensitive) order. There will always
be at least one relative ananagram.

Sample Input

ladder came tape soon leader acme RIDE lone Dreis peat

ScAlE orb eye Rides dealer NotE derail LaCeS drIed
noel dire Disk mace Rob dries

Sample Output

Disk

NotE
derail
drIed
eye
ladder
soon

分析

我的思路是用一个map容器,把字符串转为小写而且字符间排序作为键值,把出现次数和源字符串组成pair存为值。将map的键值对存入vector容器并按照源字符串排序,遍历vector,若出现次数为1次则输出源字符串。

Code

/* * @Description: Ananagrams * @version: * @Author: * @Date: 2021-04-08 09:41:45 * @LastEditors: Please set LastEditors * @LastEditTime: 2021-04-08 11:38:52 */// self#include 
#include
#include
#include
#include
using namespace std;map
> lowercase;string toLower(string str){ for (int i = 0; i < str.length(); i++) str[i] = tolower(str[i]); return str;}bool cmp(pair
> a, pair
> b){ return a.second.second < b.second.second;}int main(void){ ios::sync_with_stdio(false); cin.tie(0); string str; while (cin >> str && str[0] != '#') { string raw = str; str = toLower(str); sort(str.begin(), str.end()); if (lowercase.find(str) == lowercase.end()) lowercase[str] = make_pair(1, raw); else lowercase[str].first++; } vector
>> temp(lowercase.begin(), lowercase.end()); sort(temp.begin(), temp.end(), cmp); for (int i=0;i

转载地址:http://pjwqz.baihongyu.com/

你可能感兴趣的文章
mysql创建数据库指定字符集
查看>>
MySql创建数据表
查看>>
MySQL创建新用户以及ERROR 1396 (HY000)问题解决
查看>>
MySQL创建用户与授权
查看>>
MySQL创建用户报错:ERROR 1396 (HY000): Operation CREATE USER failed for 'slave'@'%'
查看>>
MySQL创建索引时提示“Specified key was too long; max key length is 767 bytes”
查看>>
mysql初始密码错误问题
查看>>
MySQL删除数据几种情况以及是否释放磁盘空间【转】
查看>>
Mysql删除重复数据通用SQL
查看>>
mysql判断某一张表是否存在的sql语句以及方法
查看>>
mysql加入安装策略_一键安装mysql5.7及密码策略修改方法
查看>>
mysql加强(1)~用户权限介绍、分别使用客户端工具和命令来创建用户和分配权限
查看>>
mysql加强(3)~分组(统计)查询
查看>>
mysql加强(4)~多表查询:笛卡尔积、消除笛卡尔积操作(等值、非等值连接),内连接(隐式连接、显示连接)、外连接、自连接
查看>>
mysql加强(5)~DML 增删改操作和 DQL 查询操作
查看>>
mysql加强(6)~子查询简单介绍、子查询分类
查看>>
mysql加强(7)~事务、事务并发、解决事务并发的方法
查看>>
MySQL千万级多表关联SQL语句调优
查看>>
mysql千万级大数据SQL查询优化
查看>>
MySQL千万级大表优化策略
查看>>