1050: 找出直系亲属
Posted 知我者,足以
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了1050: 找出直系亲属相关的知识,希望对你有一定的参考价值。
1050: 找出直系亲属
时间限制: 1 Sec 内存限制: 128 MB提交: 321 解决: 264
[提交][状态][讨论版]
题目描述
输入
当n和m为0时结束输入。
输出
具体含义和输出格式参见样例.
样例输入
3 2
ABC
CDE
EFG
FA
BE
0 0
样例输出
great-grandparent
-
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
using namespace std;
char cmp(char a,char b){
return a<b?0:1;
}
int main(){
int m,n;
while(cin>>m>>n&&(m!=0&&n!=0)){
string str[m];
for(int i=0;i<m;i++){
cin>>str[i];
}
char wt[n][2];
for(int i=0;i<n;i++){
for(int j=0;j<2;j++){
cin>>wt[i][j];
}
}
for(int i=0;i<n;i++){
int temp=0,index=0;
int j=m-1;
int count=0;
if(wt[i][1]<wt[i][0]){index=1;};
sort(wt[i],wt[i]+2,cmp);
while(j>=0){
if(str[j].find(wt[i][0])!=string::npos){
count++;
wt[i][0]=str[j][0];
}
if(wt[i][1]==str[j][0]) {temp=j;break;}
j--;
}
if(wt[i][1]!=str[temp][0]) count=0;
if(index==1){
while(count>2){
cout<<"great-";
count--;
}
if(count==2)
cout<<"grandparent"<<endl;
if(count==1)
cout<<"parent"<<endl;
if(count==0)
cout<<"-"<<endl;
}
else{
while(count>2){
cout<<"great-";
count--;
}
if(count==2)
cout<<"grandchild"<<endl;
if(count==1)
cout<<"child"<<endl;
if(count==0)
cout<<"-"<<endl;
}
}
}
return 0;
}
以上是关于1050: 找出直系亲属的主要内容,如果未能解决你的问题,请参考以下文章
在一个无序整数数组中,找出连续增长片段最长的一段, 增长步长是1。Example: [3,2,4,5,6,1,9], 最长的是[4,5,6]