排序专题(3)字符频率

排序专题(1)补充:


c++中有这三个函数用来处理小数向整数的转换:
2.1 2.6 -2.1 -2.6
floor : 不大于自变量的最大整数 2 2 -3 -3
ceil :不小于自变量的最大整数 3 3 -2 -2
round:四舍五入到最邻近的整数 2 3 -2 -3

但代码中经常要处理小数的四舍五入,例如对37.775进行保留两位小数的四舍五入输出,正确输出应该为37.78这个时候以上三个现成的函数不能够直接达到我们的目的。
我们用以下两种思路来达到我们的目的:
1、


float a=37.775
a=ceil(a*100+0.5)/100

2、

float a=37.775
a=ceil(a*100+0.5)/100


Time limit per test: 2.0 seconds

Memory limit: 256 megabytes

设 26 个英文字母,每个字母都对应一个使用频率,同一个字母的大小写使用频率相同。

现给定一个由 26 个英文字母构成的字符串,请将字符串按照字母使用频率由大到小重排,使用频率大的字母排在前面,使用频率小的字母排在后面,如果使用频率相同则按照字母顺序表排列,小写字母排在大写字母前面,即 a->A->b->B->c->C-d->D->……->z->Z。

例如 :

26 个字母的使用频率如下表 :

A(a)B(b)C(c)D(d)E(e)F(f)G(g)H(h)I(i)J(j)K(k)L(l)M(m)
8.191.473.833.9112.252.261.714.577.100.140.413.773.34
             
N(n)O(o)P(p)Q(q)R(r)S(s)T(t)U(u)V(v)W(w)X(x)Y(y)Z(z)
7.067.262.890.096.856.369.412.581.091.590.211.580.08

字符串 “Thisisaexample” 重排后为 “eeTaaiisshlmpx”

字符串 “AertrtsaBereDET” 重排后为 “eeeEttTaArrrsDB”。

Input

第 1 行:一个整数 T (1≤T≤10) 为问题数。

对于每个问题,有 2 行数据,按如下格式输入:

第 1 行输入 26 个浮点数,分别表示 26 个英文字母 A(a)~Z(z) 的使用频率;

第 2 行输入一个字符串,字符串长度不超过 100 个字符,字符串由 26 个英文字母构成。

Output

对于每个问题,输出一行问题的编号(0 开始编号,格式:case #0: 等)。

然后对应每个问题在一行中输出重排后的字符串。

Examples

Input
38.19 1.47 3.83 3.91 12.25 2.26 1.71 4.57 7.10 0.14 0.41 3.77 3.34 7.06 7.26 2.89 0.09 6.85 6.36 9.41 2.58 1.09 1.59 0.21 1.58 0.08Thisisaexample8.19 1.47 3.83 3.91 12.25 2.26 1.71 4.57 7.10 0.14 0.41 3.77 3.34 7.06 7.26 2.89 0.09 6.85 6.36 9.41 2.58 1.09 1.59 0.21 1.58 0.08AertrtsaBereDET8.19 1.47 3.83 3.91 12.25 2.26 1.71 4.57 7.10 0.14 0.41 3.77 3.34 7.06 7.26 2.89 0.09 6.85 6.36 9.41 2.58 1.09 1.59 0.21 1.58 0.08Thequickbrownfoxjumpsoverthelazydog
Output
case #0:eeTaaiisshlmpxcase #1:eeeEttTaArrrsDBcase #2:eeetTaooooinrrshhdclmpuufgwybvkxjqz

思路:用一个int数组来储存字母频率,然后按照字母频率排序

练习时的水题,直接po代码

#include<bits/stdc++.h>
using namespace std;
double p[26];
char str[101];
int cmp(const void *a, const void *b)
{
	char ch1 = *((char *)a);
	char ch2 = *((char *)b);
	int p1, p2;
	if (ch1 >= 'a') p1 =ch1 -'a'; else p1 =ch1- 'A';
	if (ch2 >= 'a') p2 =ch2- 'a'; else p2 = ch2-'A';
	if (p[p1] < p[p2])
		return 1;
	else if (p[p1] == p[p2])
	{
		if (p1 == p2) return ch2 - ch1;
		else
		{
			return p1 - p2;
		}
	}
	else
	{
		return -1;
	}
}
void solve() /* Define function solve() to process one case of the problem    */
{
	for (int i = 0; i < 26; i++)
		cin >> p[i];
	scanf("%s", &str);
	qsort(str, strlen(str), sizeof(str[0]), cmp);
	puts(str);
}

void init()  /* Define function init() to do global intialization if needed   */
{

}

/******************************************************************************/
/*                                                                            */
/*  DON'T MODIFY main() function anyway!                                      */
/*                                                                            */
/******************************************************************************/

#include <iostream>

void solve(); /* write function solve() to process one case of the problem    */

int main()
{
	int i, t; init();
	std::cin >> t;
	for (i = 0; i<t; i++)
	{
		std::cout << "case #" << i << ":" << std::endl;
		solve();
	}
	return 0;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值