问题及代码:
/*
*Copyright (c)2014,烟台大学计算机与控制工程学院
*All rights reserved.
*文件名称:words.cpp
*作 者:单昕昕
*完成日期:2014年12月11日
*版 本 号:v1.0
*
*问题描述:统计字母出现次数并排序
*程序输出:排序后的结果。
*/
#include<iostream>
#include <cstdio>
using namespace std;
int main()
{
char str[100],n,m[26],o='a';
gets(str);
int i,j,s=0,t,a[26]= {0};
for(i=0;i<26;++i)
m[i]=char (o+i);
for(i=0; str[i]!='\0'; ++i)
{
if(str[i]>='a'&&str[i]<='z')
a[str[i]-'a']++;
s++;
}
for(i=0; i<25; ++i)
for(j=0; j<25-i; ++j)
{
if(a[j]>a[j+1])
{
t=a[j];
a[j]=a[j+1];
a[j+1]=t;
n=m[j];
m[j]=m[j+1];
m[j+1]=n;
}
}
cout<<"\""<<str<<"\" 中各小写字母出现的次数是: "<<endl;
for(i=0; i<26; ++i)
{
if(a[i]!=0)
cout<<"\'"<<m[i]<<"\'---"<<a[i]<<endl;
}
return 0;
}
运行结果:
知识点总结:
统计小写字母出现次数并排序。
学习心得:
要排序。要输出不是0的所有结果。