編程之美——傳話遊戲題目與解答

題目: 傳話遊戲

時間限制:2000ms
單點時限:1000ms
內存限制:256MB

描述

Alice和Bob還有其他幾位好朋友在一起玩傳話遊戲。這個遊戲是這樣進行的:首先,所有遊戲者按順序站成一排,Alice站第一位,Bob站最後一位。然後,Alice想一句話悄悄告訴第二位遊戲者,第二位遊戲者又悄悄地告訴第三位,第三位又告訴第四位……以此類推,直到倒數第二位告訴Bob。兩位遊戲者在傳話中,不能讓其他人聽到,也不能使用肢體動作來解釋。最後,Bob把他所聽到的話告訴大家,Alice也把她原本所想的話告訴大家。

由於傳話過程中可能出現一些偏差,遊戲者越多,Bob最後聽到的話就與Alice所想的越不同。Bob聽到的話往往會變成一些很搞笑的東西,所以大家玩得樂此不疲。經過幾輪遊戲後,Alice注意到在兩人傳話中,有些詞彙往往會錯誤地變成其他特定的詞彙。Alice已經收集到了這樣的一個詞彙轉化的列表,她想知道她的話傳到Bob時會變成什麼樣子,請你寫個程序來幫助她。


輸入

輸入包括多組數據。第一行是整數 T,表示有多少組測試數據。每組數據第一行包括兩個整數 N 和 M,分別表示遊戲者的數量和單詞轉化列表長度。隨後有 M 行,每行包含兩個用空格隔開的單詞 a 和 b,表示單詞 a 在傳話中一定會變成 b。輸入數據保證沒有重複的 a。最後一行包含若干個用單個空格隔開的單詞,表示Alice所想的句子,句子總長不超過100個字符。所有單詞都只包含小寫字母,並且長度不超過20,同一個單詞的不同時態被認爲是不同的單詞。你可以假定不在列表中的單詞永遠不會變化。

1 ≤ T ≤ 100
小數據:2 ≤ N ≤ 10, 0 ≤ M ≤ 10 
大數據:2 ≤ N ≤ 100, 0 ≤ M ≤ 100

輸出

對於每組測試數據,單獨輸出一行“Case #c: s”。其中,c 爲測試數據編號,s 爲Bob所聽到的句子。s 的格式與輸入數據中Alice所想的句子格式相同。

樣例輸入
2
4 3
ship sheep
sinking thinking
thinking sinking
the ship is sinking
10 5
tidy tiny
tiger liar
tired tire
tire bear
liar bear
a tidy tiger is tired
樣例輸出
Case #1: the sheep is thinking
Case #2: a tiny bear is bear
解答: 首先對此題目進行解讀,要求輸入的幾個信息都是程序中會用到的,不能夠忽略掉玩這個遊戲的人數這個參數,因爲這個參數對最終輸出的結果有很大的影響,比如第一個測試數據,Alice說出的句子中的sinking,第二個人聽到變爲thinking,第三個人就又變回sinking,由於共四個人,所以最終變爲thinking,這說明了人數跟輸出結果之間的關係。在學習這個題目的時候,難倒我的是如何通過getline()讀入要傳遞的句子之後,將句子中的單詞通過給出的word list進行替換,最終採用的方法是首先將句子的字符串按照每個單詞進行拆分,通過字符串迭代器以及string的push_back方法拆分成多個以單詞爲單位的字符串,然後進行比較、替換。寫的代碼很齪,但可以實現功能,給出來爲大家提供思路。
#include "stdafx.h"
#include <iostream>
#include <string>

using namespace std;

int main()
{
	int T=0, N=0, M=0,flag,i=0,j=0,k;	
	string words[100][2];
	string results[10][100];
	string temp;
	cin>>T;
	while(T >= 1 && T <= 100)
	{
		T--;
		cin >> N >> M;
		flag=0;
		k=0;
		string sentence[100];
		while(((M > 0 && M <= 100)&&(N >= 2 && N <= 100))||((M > 0 && M <= 10)&&(N >= 2 && N <= 10)))
		{
			M--;
			cin >> words[flag][0] >> words[flag][1];
			flag++;
		}
		cin.ignore(1024,'\n');
		getline(cin, temp);
		string::iterator p = temp.begin();

		while(p != temp.end())
		{
			if(*p == ' ')
				k++;
			else
				sentence[k].push_back(*p);
			p++;
		}

		for(int m=0; m<=k; m++)
		{
			for(int q=0; q<N-1; q++)
			{
				for(int n=0; n<flag;n++)
				{
					if(sentence[m] == words[n][0])
					{
						sentence[m] = words[n][1];	
						break;
					}
				}
				results[i][m] = sentence[m];
			}
		}
		i++;
	}
	while(j < i)
	{
		cout <<"Case #"<< j+1 <<": " ;
		for(int n = 0; n <= k; n++)
		{
			cout << results[j][n] <<" ";
		}
		cout << endl;
		j++;
	}
	return 0;

}


發佈了63 篇原創文章 · 獲贊 18 · 訪問量 15萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章