/*
键盘输入一行字符,先分别统计数字、大写字母、小写字母
及其它字符的出现频率;进而分别统计每个数字、字母的出现
频率并按照从高到低的顺序将其输出。
*/
#include<iostream>
#include<string.h>
#include<iomanip>
using namespace std;
struct Mer
{
char ch;
int num;
};
int i=0,b=0,n=0;
int main()
{
Mer str[999];
char a[999];
int j,m=0,num1=0,num2=0,num3=0,num4=0;
cout<<"Input chars:"<<endl;
gets(a);
m=strlen(a);
for(i=0;i<m;i++)
{
if(a[i]>='A'&&a[i]<='Z') num1++;
else if(a[i]>='a'&&a[i]<='z') num2++;
else if(a[i]>='0'&&a[i]<='9') num3++;
else num4++;
}
printf("大写字母:%d\n小写字母:%d\n数字字符:%d\n其他字符:%d\n",num1,num2,num3,num4);
for(j=0;j<m;j++)
{
str[j].ch=a[j];
}
for(j=0;j<i-1;j++)//将字符按从小到大顺序排序
{
char temp;
for(int k=j;k<i;k++)
{
if(str[j].ch>str[k].ch)
{
temp=str[j].ch;
str[j].ch=str[k].ch;
str[k].ch=temp;
}
}
}
for(j=0;j<m;j++)
{
str[j].num=0;//初始化每个字符的数量
for(int k=j;k<m;k++)
{
if(str[j].ch==str[k].ch) //统计每个的个数
{
str[j].num++;
}
}
b++;//统计不同的字符
j+=str[j].num-1;//当有重复的单词时j就跳过重复出现的单词
}
cout<<endl<<endl<<endl;
for(j=0;j<m-1;j++)//将单词按字典顺序排序
{
Mer temp;
for(int k=j;k<m;k++)
{
if(str[j].num<str[k].num)
{
temp=str[j];
str[j]=str[k];
str[k]=temp;
}
}
cout<<setw(4)//控制域宽
<<setiosflags(ios::left)//左对齐
<<str[j].ch<<" number:"<<str[j].num<<endl;
n++;
if(n==b)break;//输完不同的字符之后就停止输出
}
return 0;
}
键盘输入一行字符,先分别统计数字、大写字母、小写字母
及其它字符的出现频率;进而分别统计每个数字、字母的出现
频率并按照从高到低的顺序将其输出。
*/
#include<iostream>
#include<string.h>
#include<iomanip>
using namespace std;
struct Mer
{
char ch;
int num;
};
int i=0,b=0,n=0;
int main()
{
Mer str[999];
char a[999];
int j,m=0,num1=0,num2=0,num3=0,num4=0;
cout<<"Input chars:"<<endl;
gets(a);
m=strlen(a);
for(i=0;i<m;i++)
{
if(a[i]>='A'&&a[i]<='Z') num1++;
else if(a[i]>='a'&&a[i]<='z') num2++;
else if(a[i]>='0'&&a[i]<='9') num3++;
else num4++;
}
printf("大写字母:%d\n小写字母:%d\n数字字符:%d\n其他字符:%d\n",num1,num2,num3,num4);
for(j=0;j<m;j++)
{
str[j].ch=a[j];
}
for(j=0;j<i-1;j++)//将字符按从小到大顺序排序
{
char temp;
for(int k=j;k<i;k++)
{
if(str[j].ch>str[k].ch)
{
temp=str[j].ch;
str[j].ch=str[k].ch;
str[k].ch=temp;
}
}
}
for(j=0;j<m;j++)
{
str[j].num=0;//初始化每个字符的数量
for(int k=j;k<m;k++)
{
if(str[j].ch==str[k].ch) //统计每个的个数
{
str[j].num++;
}
}
b++;//统计不同的字符
j+=str[j].num-1;//当有重复的单词时j就跳过重复出现的单词
}
cout<<endl<<endl<<endl;
for(j=0;j<m-1;j++)//将单词按字典顺序排序
{
Mer temp;
for(int k=j;k<m;k++)
{
if(str[j].num<str[k].num)
{
temp=str[j];
str[j]=str[k];
str[k]=temp;
}
}
cout<<setw(4)//控制域宽
<<setiosflags(ios::left)//左对齐
<<str[j].ch<<" number:"<<str[j].num<<endl;
n++;
if(n==b)break;//输完不同的字符之后就停止输出
}
return 0;
}