使用Java完成《算法导论》习题2.2-2

public class SelectionSort2_2_2
{
	/**
	 * 选择法排序,使已排序子数组的最后一个元素与未排序序列最小值互换位置
	 * @date 2015-6-13
	 * @author lemma
	 */

	// doSort方法
	public void doSort(int[] Data)
	{
		//找出已排序子数组最后的元素
		for (int index = 0; index < Data.length - 1; index++)
		{
			int temp = Data[index];
			int tempIndex = index;
			
			//找出未排序序列中小于已排序子数组的元素的最小值
			for (int selectedIndex = index + 1; selectedIndex < Data.length; selectedIndex++)
			{
				if (Data[selectedIndex] < temp)
				{
					temp = Data[selectedIndex];
					tempIndex = selectedIndex;
				}
			}
			//如果最小值存在,与已排序子数组的最后一位交换位置
			if (temp != Data[index])
			{
				Data[tempIndex] = Data[index];
				Data[index] = temp;
			}
		}
		for (int data : Data)
		{
			System.out.print(data + "  ");
		}
	}

	public static void main(String args[])
	{
		int Data[] = { 15, 65, 23, 48, 21, 4, 68 };
		new SelectionSort2_2_2().doSort(Data);
	}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值