PAT乙级-1052 卖个萌(三种解法)

题目描述

在这里插入图片描述

实现代码

实现代码一

#include<iostream>
#include<string>

using namespace std;

int main(void)
{
	string a,b,c;
	getline(cin,a);
	getline(cin,b);
	getline(cin,c);
	int n;
	cin>>n;
	int d;
	for(int i=0;i<n;i++)
	{
		int flag=0;
		string aa={};
		for(int j=0;j<5;j++)//[0:左手]([1:左眼][2:口][3:右眼])[4:右手]
		{
			cin>>d;
			if(d<=0)
			{
				flag=1;
				break;
			}
			int flag1=0;
			int k,m;
			int len;
			string s;
			if(j==0||j==4)//选择判断数组 
			{
				len=a.length();
				s=a;
			}
			if(j==1||j==3)
			{
				len=b.length();
				s=b;
			}
			if(j==2)
			{
				len=c.length();
				s=c;
			}
			
			for(k=0,m=0;k<len;k++)//找到对应表情 
			{
				if(s[k]=='[')
				{
					m++;
				}
				if(d==m)
				{
					flag1=1;
					break;
				}
			}
			if(flag1!=1&&k==len)
			{
				flag=1;
				break;
			}
			
			if(s[k]=='[') k++;
			for(;;k++)
			{
				if(s[k]==']')	break;
				if(s[k]!=' '&&s[k]!='['&&s[k]!=']') aa+=s[k];
			}
			if(j==0)
			{
				aa+='(';
			}
			if(j==3)
			{
				aa+=')';
			}
		}
		if(flag==1)
		{
			cout<<"Are you kidding me? @\\/@"<<endl;	
		}
		else
		{
			cout<<aa<<endl;
		}
	}
}

实现代码一-平台测试结果
在这里插入图片描述
实现代码二
(参考韩旭的代码后写出)

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

string aa[11],bb[11],cc[11];

int ex(string a,string b[])
{
	int k=0;
	int flag=0;
	for(int i=0;i<a.length();i++)
	{
		if(a[i]=='[')
		{
			flag=1;
		}
		if(a[i]!='['&&a[i]!=' '&&a[i]!=']'&&flag)
		{
			b[k]+=a[i];
		}
		if(a[i]==']')
		{
			flag=0;
			k++;
		}
	}
	return k;//返回表情集长度 
}

int main(void)
{
	string a,b,c;
	getline(cin,a);
	getline(cin,b);
	getline(cin,c);
	int k1=ex(a,aa);
	int k2=ex(b,bb);
	int k3=ex(c,cc);
	int n;
	cin>>n;
	int d;
	for(int i=0;i<n;i++)
	{
		int flag=0;
		int d[5];
		for(int j=0;j<5;j++)//[0:左手]([1:左眼][2:口][3:右眼])[4:右手]
		{
			cin>>d[j];
			if(d[j]<=0)
			{
				flag=1;
			}
		}
		if(!flag&&d[0]<k1+1&&d[4]<k1+1&&d[1]<k2+1&&d[3]<k2+1&&d[2]<k3+1)
		{
			cout<<aa[d[0]-1]<<"("<<bb[d[1]-1]<<cc[d[2]-1]<<bb[d[3]-1]<<")"<<aa[d[4]-1]<<endl;
		}
		else
		{
			cout<<"Are you kidding me? @\\/@"<<endl;
		}
	}
}

实现代码二-平台测试结果
在这里插入图片描述
实现代码三(柳神的代码)

#include <iostream>
#include <vector>
using namespace std;
int main() {
    vector<vector<string> > v;
    for(int i = 0; i < 3; i++) {
        string s;
        getline(cin, s);
        vector<string> row;
        int j = 0, k = 0;
        while(j < s.length()) {
            if(s[j] == '[') {
                while(k++ < s.length()) {
                    if(s[k] == ']') {
                        row.push_back(s.substr(j+1, k-j-1));
                        break;
                    }
                }
            }
            j++;
        }
        v.push_back(row);
    }
    int n;
    cin >> n;
    for(int i = 0; i < n; i++) {
        int a, b, c, d, e;
        cin >> a >> b >> c >> d >> e;
        if(a > v[0].size() || b > v[1].size() || c > v[2].size() || d > v[1].size() || e > v[0].size() || a < 1 || b < 1 || c < 1 || d < 1 || e < 1) {
            cout << "Are you kidding me? @\\/@" << endl;
            continue;
        }
        cout << v[0][a-1] << "(" << v[1][b-1] << v[2][c-1] << v[1][d-1] << ")" << v[0][e-1] << endl;
    }
    return 0;
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值