我是靠谱客的博主 繁荣灰狼,最近开发中收集的这篇文章主要介绍catscan朋友的一个问题,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

 还是找你帮我编个程序,我最近用脑过度- - 
输入一串字符,以“?”结束,统计各字母出现的次数,并按字母出现的多少输出
先输出字母出现多的,次数相同的按照字母表顺序输出,不出现的不输出
主要是后面那句的- -要求

#include<stdio.h>
#include<string.h>
#include<stdlib.h>

typedef struct Node{
	int x;
	char c;
}Node;

int cmp (const void* a,const void *b)
{
	if((*(Node*)a).x==(*(Node*)b).x) return (*(Node*)b).c - (*(Node*)a).c;
	else return (*(Node*)b).x - (*(Node*)a).x;
}

int main()
{
	int i;
	Node num[125];
	char c;
	memset(num,0,sizeof(num));
	while((c=getchar())!='?')
	{
		num[c-'0'].x++;
		num[c-'0'].c = c; 
	}
	qsort(num,125,sizeof(num[0]),cmp);
	for(i=0;i<125;i++)
		if(num[i].x>=1 && ((num[i].c>='a' && num[i].c<='z') || (num[i].c>='A' && num[i].c<='Z')))
			printf("%cn",num[i].c);
	return 0;
}


 
 

转载于:https://www.cnblogs.com/lgh1992314/archive/2012/11/18/5835304.html

最后

以上就是繁荣灰狼为你收集整理的catscan朋友的一个问题的全部内容,希望文章能够帮你解决catscan朋友的一个问题所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(39)

评论列表共有 0 条评论

立即
投稿
返回
顶部