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

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

小白的poj試練之1002

2019-11-11 03:13: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;}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 稷山县| 吉水县| 城固县| 陆河县| 德惠市| 苍溪县| 屏山县| 明星| 松江区| 防城港市| 井陉县| 策勒县| 杂多县| 康保县| 比如县| 民县| 通州区| 舞钢市| 边坝县| 自贡市| 吉林市| 县级市| 苏州市| 登封市| 梓潼县| 北海市| 精河县| 元阳县| 陆河县| 泉州市| 五原县| 云和县| 含山县| 财经| 和硕县| 平乡县| 金门县| 金山区| 乐陵市| 布拖县| 汉寿县|