POJ 1007 DNA Sorting - 字符串比较 - 排序

8 篇文章 0 订阅

POJ 1007 DNA Sorting

题意:字符串比较,逆序数排序。难度:1星。

应注意排序的稳定性。

不稳定的排序算法:选择排序、快速排序、希尔排序、堆排序;
稳定的排序算法:冒泡排序、插入排序、归并排序和基数排序。

/*
 *	POJ 1007 DNA Sorting
 *		字符串比较;逆序数排序;
 *
 *	将序号与对应逆序数绑定:
 *		inversion[i] = inversion[i] * 100 + i;
 *	排序;
 *
 */

#include <iostream>

using namespace std;

int main()
{
	char input[100][56];
	int length, number;
	int inversion[100];
	int i, j, k, tmp;

	cin >> length >> number;
	for (i = 0; i < number; i++)
	{
		cin >> input[i];
		
		for (j = 0, inversion[i] = 0; j < length - 1; j++)
		{
			for (k = j + 1; k < length; k++)
			{
				if (input[i][j] > input[i][k])
				{/* 计算逆序数 */
					inversion[i]++;
				}
			}
		}//for (int j = 0; j < length - 1; j++)

		inversion[i] = inversion[i] * 100 + i;	/* 将序号与对应逆序数绑定 */
	}//for (int i = 0; i < number; i++)

	/* 将逆序数升序排序 */
	for (i = 0; i < number - 1; i++)
	{/* 冒泡排序 */
		for (j = 0; j < number - 1 - i; j++)
		{
			if (inversion[j] > inversion[j + 1])
			{
				tmp = inversion[j + 1];
				inversion[j + 1] = inversion[j];
				inversion[j] = tmp;
			}
		}
	}

	for (i = 0; i < number; i++)
	{
		cout << input[inversion[i] % 100] << endl;
	}

	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值