1. 程式人生 > >華為[程式設計題] 撲克牌大小 (string的使用)

華為[程式設計題] 撲克牌大小 (string的使用)

[程式設計題] 撲克牌大小

時間限制:10秒

空間限制:131072K

撲克牌遊戲大家應該都比較熟悉了,一副牌由54張組成,含3~A,2各4張,小王1張,大王1張。牌面從小到大用如下字元和字串表示(其中,小寫joker表示小王,大寫JOKER表示大王):) 
3 4 5 6 7 8 9 10 J Q K A 2 joker JOKER 
輸入兩手牌,兩手牌之間用“-”連線,每手牌的每張牌以空格分隔,“-”兩邊沒有空格,如:4 4 4 4-joker JOKER
請比較兩手牌大小,輸出較大的牌,如果不存在比較關係則輸出ERROR

基本規則:
(1)輸入每手牌可能是個子,對子,順子(連續5張),三個,炸彈(四個)和對王中的一種,不存在其他情況,由輸入保證兩手牌都是合法的,順子已經從小到大排列;
(2)除了炸彈和對王可以和所有牌比較之外,其他型別的牌只能跟相同型別的存在比較關係(如,對子跟對子比較,三個跟三個比較),不考慮拆牌情況(如:將對子拆分成個子)
(3)大小規則跟大家平時瞭解的常見規則相同,個子,對子,三個比較牌面大小;順子比較最小牌大小;炸彈大於前面所有的牌,炸彈之間比較牌面大小;對王是最大的牌;
(4)輸入的兩手牌不會出現相等的情況。

答案提示:
(1)除了炸彈和對王之外,其他必須同類型比較。
(2)輸入已經保證合法性,不用檢查輸入是否是合法的牌。
(3)輸入的順子已經經過從小到大排序,因此不用再排序了.

輸入描述:

輸入兩手牌,兩手牌之間用“-”連線,每手牌的每張牌以空格分隔,“-”兩邊沒有空格,如4 4 4 4-joker JOKER。

輸出描述:

輸出兩手牌中較大的那手,不含連線符,撲克牌順序不變,仍以空格隔開;如果不存在比較關係則輸出ERROR。

輸入例子1:

4 4 4 4-joker JOKER

輸出例子1:

joker JOKER

解題思路: 想要AC本題也簡單,關鍵是對String函式的使用熟練,還有注意count函式的用法!!!

#include <iostream>
#include <string>
#include <algorithm>
using namespace std;


int main(void){
    string str;  
    while(getline(cin,str)){
    	if(str.size() == 0)
    		break;
    	if(str.find("joker JOKER") != -1){
    		cout<<"joker JOKER"<<endl;
    		continue;
    	}
    	int pos = str.find('-');
    	string fir = str.substr(0,pos);
    	string sec = str.substr(pos+1);
    	int t1 = count(fir.begin(),fir.end(),' ');//count函式的使用 
    	int t2 = count(sec.begin(),sec.end(),' ');
    	string ch1 = fir.substr(0,fir.find(' '));
    	string ch2 = sec.substr(0,fir.find(' '));
    	string num = "345678910JQKA2jokerJOKER";//通過構建大小字串與find來比較大小!!! 
    	if(t1 == t2){
    		if(num.find(ch1) > num.find(ch2))
    			cout<<fir<<endl;
    		else
    			cout<<sec<<endl;	
    	}else{
    		if(t1 == 3)
    			cout<<fir<<endl;
    		else if(t2 == 3)
    			cout<<sec<<endl;
    		else
    			cout<<"ERROR"<<endl;
    	}
    }
}