#UVa:156-Ananagrams

灆洢 2015-05-05 12:29:15

先將文字改成全小寫並照字母排序,接著就看每個詞轉換後的字串是否有相等的。有相等的就不輸出,而沒有相等的就照原字串輸出即可。

C++(0.009)

/*******************************************************/
/* UVa 156 Ananagrams                                  */
/* Author: Maplewing [at] knightzone.studio            */
/* Version: 2015/05/04                                 */
/*******************************************************/
#include <iostream>
#include <cstdio>
#include <cctype>
#include <string>
#include <map>
#include <algorithm>
#include <queue>
using namespace std;

int main(){
  map<string, string> ananagrams;
  string word;
  while( cin >> word && word != "#"){
    string query = word;
    transform(word.begin(), word.end(), query.begin(), ::tolower);
    sort(query.begin(), query.end());

    if( ananagrams.find(query) == ananagrams.end() ){
      ananagrams
= word; } else{ ananagrams
= "#"; } } priority_queue< string, vector<string>, greater<string> > sortByValue; for( map<string, string>::iterator it = ananagrams.begin() ; it != ananagrams.end() ; ++it ){ if( it->second != "#" ){ sortByValue.push(it->second); } } while( !sortByValue.empty() ){ printf("%s\n", sortByValue.top().c_str() ); sortByValue.pop(); } return 0; }

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *

這個網站採用 Akismet 服務減少垃圾留言。進一步瞭解 Akismet 如何處理網站訪客的留言資料