UOJ Logo

NOI.AC

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#195713#3418. 鹅鸭杀I_AM_AKING_IOI10012ms1556kbC++1.2kb2023-10-18 20:50:432023-10-18 22:33:16

answer

#include<bits/stdc++.h>
using namespace std;
int n;
string name[1010],id[1010],place[1010],xc[1010];
map<string,int> m;
map<string,bool> m1;
int main(){
	ios::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);
	cin>>n;
	for(int i=1;i<=n+1;i++){
		string s;
		getline(cin,s);
		if(i==1) continue;
		int j;
		for(j=0;j<s.size();j++){
			if(s[j]==' ') break;
			name[i]+=s[j];
		}
		int kg=0;
		for(j=0;j<s.size();j++){
			if(s[j]==' '||s[j]==',') kg++;
			if(kg==3){
				id[i]+=s[j];
			}else if(kg>3) break;
		}
		kg=0;
		for(j=0;j<s.size();j++){
			if(s[j]==' ') kg++;
			if(kg==7){
				place[i]+=s[j];
			}
		}
		m[place[i]]++;
		if(id[i]==" duck") m1[place[i]]=true;
//		cout<<id[i]<<"\n";
	}
	for(int i=1;i<=n+1;i++){
		if(i==1) continue;
//		cout<<"有无鸭:"<<m1[place[i]]<<" "<<"有几只动物:"<<m[place[i]]<<" 身份:"<<id[i]<<"\n";
		if(m1[place[i]]&&m[place[i]]>1&&id[i]!=" duck") cout<<name[i]<<" "<<"is"<<" "<<"dead"<<"\n";
		else if(m1[place[i]]&&m[place[i]]>1&&id[i]==" duck") cout<<name[i]<<" "<<"is"<<" "<<"alive"<<"\n";
		else if(m[place[i]]==1||id[i]==" duck") cout<<name[i]<<" "<<"is"<<" "<<"alive"<<"\n";
		else if(!m1[place[i]]) cout<<name[i]<<" "<<"is"<<" "<<"alive"<<"\n";
		
	}
}

详细

小提示:点击横条可展开更详细的信息

Test #1:

score: 10
Accepted
time: 1ms
memory: 1300kb

input:

1
DnONuKkfsK is a duck, it is at VxdjvTXugQrxHcBy

output:

DnONuKkfsK is alive

result:

ok single line: 'DnONuKkfsK is alive'

Test #2:

score: 10
Accepted
time: 1ms
memory: 1300kb

input:

1
h is a goose, it is at DgPHXhVJtkESkHmf

output:

h is alive

result:

ok single line: 'h is alive'

Test #3:

score: 10
Accepted
time: 0ms
memory: 1304kb

input:

2
HRiAYWN is a goose, it is at EL
dgwgYboiuaytmJOAv is a duck, it is at EL

output:

HRiAYWN is dead
dgwgYboiuaytmJOAv is alive

result:

ok 2 lines

Test #4:

score: 10
Accepted
time: 0ms
memory: 1300kb

input:

2
izNydjl is a goose, it is at qYWlAosa
EISnxurnHqHNKDD is a goose, it is at qYWlAosa

output:

izNydjl is alive
EISnxurnHqHNKDD is alive

result:

ok 2 lines

Test #5:

score: 10
Accepted
time: 1ms
memory: 1304kb

input:

10
NSWzSOl is a duck, it is at VCLAQReUMFYoH
owVUjFuAPuutSaKhLqh is a duck, it is at ZYPmZsegdxJOuB
...

output:

NSWzSOl is alive
owVUjFuAPuutSaKhLqh is alive
iamfqstvZbCYSDhlDnbq is alive
T is alive
zGub is alive...

result:

ok 10 lines

Test #6:

score: 10
Accepted
time: 0ms
memory: 1304kb

input:

10
kjbxCSWpMH is a duck, it is at FIlDOBA
gxRn is a duck, it is at zXofss
vIFtyFL is a duck, it is a...

output:

kjbxCSWpMH is alive
gxRn is alive
vIFtyFL is alive
PFeZj is alive
uEy is alive
qnoZYPzR is alive
Rff...

result:

ok 10 lines

Test #7:

score: 10
Accepted
time: 0ms
memory: 1304kb

input:

10
CdhUNaBieDYujJ is a goose, it is at ftZTshCjDGgjvPZ
e is a duck, it is at HHvP
fnjTJMUYgydjEeAFet...

output:

CdhUNaBieDYujJ is alive
e is alive
fnjTJMUYgydjEeAFet is alive
Vvc is alive
MLHmWVs is alive
AYDTmkf...

result:

ok 10 lines

Test #8:

score: 10
Accepted
time: 6ms
memory: 1552kb

input:

1000
zS is a duck, it is at uZoViqfzXzBHnojfjo
WUzyrypHYFMkE is a goose, it is at RqXtorsLNPVXWX
mbV...

output:

zS is alive
WUzyrypHYFMkE is dead
mbVP is alive
iWelC is alive
DqMTir is alive
Zr is alive
BsHCmmN i...

result:

ok 1000 lines

Test #9:

score: 10
Accepted
time: 0ms
memory: 1556kb

input:

1000
luK is a duck, it is at Jr
kz is a duck, it is at Q
momuTR is a duck, it is at beRModCS
HmqEgsw...

output:

luK is alive
kz is alive
momuTR is alive
HmqEgswLg is dead
uFNEeUULkDT is alive
uQgDGhomNgYQuwndOxKn...

result:

ok 1000 lines

Test #10:

score: 10
Accepted
time: 3ms
memory: 1552kb

input:

1000
IbBJmdORPKZQEUANbGl is a duck, it is at OJplxaPZjvPj
BzokAqyWjUIVWu is a duck, it is at xxYRvKG...

output:

IbBJmdORPKZQEUANbGl is alive
BzokAqyWjUIVWu is alive
tLHbuTjOxzopobuOMg is alive
rLeadcccgsTAuIbpOGU...

result:

ok 1000 lines

Extra Test:

score: 0
Extra Test Passed