国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

小白的poj試練之1002

2019-11-11 04:27:41
字體:
來源:轉載
供稿:網友

1002:方便記憶的電話號碼

  此題需要將一組用可能用字母表達的電話號碼中重復的電話號碼統計出來并按順序打印出來。

  剛拿到此題我是蒙蔽的,于是百度了一下解法,認識到了map的妙用,大概相當于python中的字典。

  當然也有些慢慢看出來的體會,比如新建一個map中的鍵值對時如果不給value賦值那么應該是默認為零,譬如:

  map<string,int>mp;

    string s;

    map[s]+=1;

    代碼沒有寫全,想要表達的是這個map[s]+=1應該就是初始創建時為零,也就是說如果按上面代碼運行s對應的值應該為1。

    還有一個是map是自動按照鍵的大小來排序的,所以說使用map后就不需要再為排序問題糾結了,只需要記住鍵值是升序就可以了。

    顯然使用map非常方便于統計數據對。將最終提交代碼貼在下面:

    

#include<iostream>#include<map>#include<string>using namespace std;char convert(char cha){    switch(cha)	{	case 'A':	case 'B':	case 'C':		return '2';	case 'D':	case 'E':	case 'F':		return '3';	case 'G':	case 'H':	case 'I':		return '4';	case 'J':	case 'K':	case 'L':		return '5';	case 'M':	case 'N':	case 'O':		return '6';	case 'P':	case 'R':	case 'S':		return '7';	case 'T':	case 'U':	case 'V':		return '8';	case 'W':	case 'X':	case 'Y':		return '9';	default:		return cha;	}}int main(){	map<string, int>mp;	int count;	cin >> count;	string str;	bool find = false;	for (int i = 0; i < count; i++)	{		cin >> str;		string s = "";		for (int j = 0; j < int(str.length()); j++)		{			if ((str[j] >= '0'&&str[j] <= '9') || (str[j] >= 'A'&&str[j] <= 'Z'))				s += convert(str[j]);		}		mp[s] += 1;	}	map < string, int >::iterator it;	for (it = mp.begin(); it != mp.end(); it++)	{		if (it->second != 1)		{			find = true;			for (int i = 0; i < 7; i++)			{				cout << it->first[i];				if (i == 2)					cout << '-';			}			cout << ' ';			cout << it->second<<endl;		}	}	if (!find)		cout << "No duplicates."<<endl;	return 0;}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 吴堡县| 礼泉县| 钦州市| 梓潼县| 黑龙江省| 永济市| 栾城县| 平顶山市| 科尔| 南通市| 涪陵区| 蓬溪县| 腾冲县| 绥江县| 乐陵市| 抚州市| 临海市| 海伦市| 湘潭县| 保定市| 古浪县| 会泽县| 晋城| 金乡县| 栖霞市| 黎城县| 郧西县| 桂林市| 佛学| 仪征市| 原阳县| 尖扎县| 鸡东县| 浙江省| 饶阳县| 新丰县| 江安县| 济阳县| 子长县| 漠河县| 兴化市|