NKOJ 7339 礼炮

文章描述了一个编程问题,要求计算从给定字符串中最多能组成多少个由特定字母组成的礼炮。两个解决方案被提及,一个是作者的,另一个是其父亲的,后者在时间和内存效率上更优。
摘要由CSDN通过智能技术生成
礼炮
时间限制 : - MS   空间限制 : - KB 

评测说明 : 1s 256MB

问题描述

果老师想为信竞之王的诞生献上礼炮!

有一串长度为的小写字母组成的字符串,果老师可以从中挑选‘k’ ‘i’ ‘n’ ‘g’四个字符组成一支礼炮,或者从中挑选‘k’ ‘i’ ‘n’ ‘g’ ‘i’ ‘n’ ‘g’七个字符组成两支礼炮。请问果老师为信竞之王的诞生最多能献上多少礼炮?

输入格式

第一行一个正整数  ,表示字符串长度,。

第二行一串只含有小写字母的字符串。

输出格式

输出果老师为信竞之王的诞生能献上的最多礼炮数。

样例输入

4
king

样例输出

1

我的代码:

#include<iostream>
using namespace std;
int k,i,n,g,cnt,x,y;
char a[10000001];
int main(){
	int s;
	scanf("%d",&s);
	scanf("%s",a);
	for(int j=0;j<s;j++){
		if(a[j]=='k'){
			k++;
			continue;
		}
		if(a[j]=='i'){
			i++;
			continue;
		}
		if(a[j]=='n'){
			n++;
			continue;
		}
		if(a[j]=='g'){
			g++;
			continue;
		}
	}
	x=min(i,n);
	y=min(x,g);
	if(k<=(y/2)){
		cout<<k*2;
		return 0;
	}
	cout<<y;
}

 

总用时

358 MS

最大用时

187 MS

最大内存

12232 KB

我爸的代码 :

#include<iostream>
using namespace std;
int cnt,x,y;
char a[10000001];
int m[26];
int main(){
	int s;
	scanf("%d",&s);
	scanf("%s",a);
	for(int j=0;j<s;j++){
		m[a[j]-'a']++;
	}
	int k=m['k'-'a'];
	int i=m['i'-'a'];
	int n=m['n'-'a'];
	int g=m['g'-'a'];
	x=min(i,n);
	y=min(x,g);
	if(k<=(y/2)){
		printf("%d",k*2);
		return 0;
	}
	printf("%d",y);
}

总用时

124 MS

最大用时

93 MS

最大内存

10496 KB

 

看来我还是不如我爸......

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值