LeetCode之Unique Morse Code Words

题目描述

26个小写字母对应于以下的Morse code
[".-","-...","-.-.","-..",".","..-.","--.","....","..",".---","-.-",".-..","--","-.","---",".--.","--.-",".-.","...","-","..-","...-",".--","-..-","-.--","--.."]
输入n个单词将其转换为给出的Morse code,输出转换后的不同的morse code的个数,举例:
输入: words = ["gin", "zen", "gig", "msg"]
输出:2

注意:单词的个数在100个以内
	每个单词的长度为1-12
	单词均为小写字母

解决思路

将转换后的morse code 存在set中,之后输出set的长度即可,因为set中存放的是不重复的数据

C++ contains 之 set、map

  • set
    set是有序集合,unordered_set是无序集合,存放不重复的数据
    mutiset是有序集合,unordered_set是无序集合,可存放重复的数据
  • map
    map(有序)、unordered_map(无序),存放不重复的键值对
    mutimap(有序)、unordered_map(无序) ,可存放重复的键值对

代码实现

	int uniqueMorseRepresentations(vector<string>& words) {
	        vector<string> morse = {".-","-...","-.-.","-..",".","..-.","--.","....","..",".---","-.-",".-..","--","-.","---",".--.","--.-",".-.","...","-","..-","...-",".--","-..-","-.--","--.."};
	        vector<string>::iterator it_morse = morse.begin();
	        unordered_set<string> result;
	
	        for(auto str : words){
	            string temp = "";
	            for(auto it = str.cbegin(); it != str.cend(); ++it){
	                temp += *(it_morse + ((*it) - 97));   
	            }
	            result.insert(temp);
	        }
	
	        int count = (int)result.size();
	        return count;
	    }

欢迎指正,如转载请注明出处

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值