XTU OJ 1170 学习笔记

ICPC

题目描述

ACM/ICPC比赛涉及的知识点非常多,一个队伍三个人需要能够互补。一个队伍某个知识点的高度是三个人中水平最高的那个人决定。现在给你三个人的每个知识点的水平情况,请计算一下这个队伍的水平。

输入

存在多个样例。每个样例的第一行是一个整数N(3≤N≤100),表示所有知识点的个数。 以后三行为每个人每个知识点的水平情况。水平用A到E表示,一共5级,A最强,E最弱,依次递减。

输出

每个样例输出两行,第一行为一个字符串,一个队伍的各个知识点的水平情况。第二行是5个整数,表示5个级别知识点的个数,每个整数之间有一个空格。

样例输入
复制代码
3
ABC
BBB
AAE
4
DDBD
DEDC
CDDE
0
样例输出
复制代码
AAB
2 1 0 0 0
CDBC
0 1 2 1 0
cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

const int N=110;
char s1[N],s2[N],s3[N],m[N],num[10];

int main()
{
	int n;
	while(~scanf("%d",&n))
	{
		if(n==0)	break;
		scanf("%s",s1);
		scanf("%s",s2);
		scanf("%s",s3);
		memset(m,0,sizeof m);
		for(int i=0;i<n;i++)
		{
			m[i]=min({s1[i],s2[i],s3[i]});
		}
		for(int i=0;i<n;i++)	printf("%c",m[i]);
		printf("\n");
		memset(num,0,sizeof num);
		for(int i=0;i<n;i++)	num[m[i]-'A']++;
		for(int i=0;i<4;i++)	printf("%d ",num[i]);
		printf("%d\n",num[4]);
	}
	return 0;
}

每一个知识点的水平是由最强的人决定的,这就是所谓的长板效应。靠前的字母表示水平高,我们实际上只需要找到每一个知识点对应的最靠前的字母即可,找到每一列最靠前的字母,就表示找到了最高的水平,然后一次输出代表最高水平的字母即可。

使用一个计数器来存储每一个最高水平字母出现的次数,然后把这个次数依次输出即可

注意一下代码细节,使用min函数寻找最小值,如果要寻找三个元素里面的最小值,可以使用大括号括起来,像这样子

cpp 复制代码
m[i]=min({s1[i],s2[i],s3[i]});

每一次循环都要初始化m数组和计数数组,防止上一次循环的结果对后一次循环造成影响

注意输出的格式要求,有时候最后一个元素后面不能有空格

相关推荐
Lester_11015 分钟前
嵌入式学习笔记 - freeRTOS vTaskPlaceOnEventList()函数解析
笔记·学习
机器学习之心21 分钟前
机器学习用于算法交易(Matlab实现)
算法·机器学习·matlab
AL流云。22 分钟前
【优选算法】C++滑动窗口
数据结构·c++·算法
qq_429879671 小时前
省略号和可变参数模板
开发语言·c++·算法
moxiaoran57532 小时前
uni-app学习笔记二十三--交互反馈showToast用法
笔记·学习·uni-app
飞川撸码2 小时前
【LeetCode 热题100】网格路径类 DP 系列题:不同路径 & 最小路径和(力扣62 / 64 )(Go语言版)
算法·leetcode·golang·动态规划
Neil今天也要学习3 小时前
永磁同步电机参数辨识算法--IPMSM拓展卡尔曼滤波全参数辨识
单片机·嵌入式硬件·算法
yzx9910133 小时前
基于 Q-Learning 算法和 CNN 的强化学习实现方案
人工智能·算法·cnn
亮亮爱刷题4 小时前
算法练习-回溯
算法
眼镜哥(with glasses)4 小时前
蓝桥杯 国赛2024python(b组)题目(1-3)
数据结构·算法·蓝桥杯