【题解】 洛谷P1598 垂直竖状图(模拟 字符串)

纯模拟即可。

运用gets读入一整行字符,并记录其中每个字母出现的个数。读入完毕后记录下最多的字母出现的个数。然后从那个数开始循环,内层对每一个字母进行判断,如果比它小就输出空格,否则输出星号+空格。最后一行输出字母+空格即可

#include<cstdio>
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<cmath>
using namespace std;
char a[110];
int num[27];
int main()
{
	int n,len,mmax=-100;
	for(int i=0;i<4;i++)
	{
		gets(a);
		len=strlen(a);
		for(int j=0;j<len;j++)
		{
			if(a[j]>='A'&&a[j]<='Z')
			{
				num[a[j]-'A']++;
			}
		}
	}
	for(int i=0;i<26;i++)
	{
		mmax=max(mmax,num[i]);
	}
	
	for(int i=mmax;i>0;i--)
	{
		for(int j=0;j<26;j++)
		{
			if(num[j]<i) 
			{
				cout<<' '<<' ';
				continue;
			}
			else if(num[j]>=i) 
			{
				cout<<'*'<<' ';
				continue;
			}
		}
		
		cout<<endl;
	}
	for(int i=0;i<26;i++)
	{
		printf("%c ",i+'A');
	}
	return 0;
}

猜你喜欢

转载自blog.csdn.net/rem_inory/article/details/81164467