第三周作业——冒泡排序和归并排序

import java.io.BufferedReader;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

public class test2 {

	public static void main(String[] args) {
		List<Integer> arrayList = new ArrayList();

		try {
			BufferedReader input = new BufferedReader(new FileReader(
					"largeW.txt"));
			String temp = null;
			while ((temp = input.readLine()) != null) {
				arrayList.add(Integer.valueOf(temp.trim()));
			}

//			for (Iterator<Integer> iterator = arrayList.iterator(); iterator
//					.hasNext();) {
//				Integer object = iterator.next();
//				System.out.println(object);
//			}
			
			//冒泡排序算法调用
//			BubbleSort(arrayList);
			
			//归并算法调用
			Object[] tempArray = arrayList.toArray();
			int[] tempArrayInt = new int[tempArray.length];
			for (int i = 0; i < tempArrayInt.length; i++) {
				tempArrayInt[i] = Integer.parseInt(tempArray[i].toString());
			}
			tempArrayInt = mergeSort(tempArrayInt);
			
			for (int i = 0; i < tempArrayInt.length; i++) {
				System.out.println(tempArrayInt[i]);
			}
			

//			for (Iterator<Integer> iterator = arrayList.iterator(); iterator
//					.hasNext();) {
//				Integer object = iterator.next();
//				System.out.println(object);
//			}

		} catch (FileNotFoundException e) {
			System.out.println("文件不存在。");
			e.printStackTrace();
		} catch (NumberFormatException e) {
			System.out.println("类型不符错误。");
			e.printStackTrace();
		} catch (IOException e) {
			System.out.println("输入输出错误。");
			e.printStackTrace();
		}

		// System.out.println(Integer.valueOf((" 18940").trim()));
	}
	
	
	//**************冒泡排序法
	public static void BubbleSort(List list) {
		for (int i = list.size(); i != 0; i--) {
			for (int j = 0; j != i - 1; j++) {
				Integer tempa = (Integer) list.get(j);
				Integer tempb = (Integer) list.get(j + 1);
				int a = tempa.intValue();
				int b = tempb.intValue();

				// 交换位置部分
				if (a < b) {
					System.out.println(a);
					list.remove(j);
					list.add(j, tempb);
					list.remove(j + 1);
					list.add(j + 1, tempa);
				}
			}
		}

	}
	
	
	
	//**************归并排序法
	public static int[] mergeSort(int[] arr) {
		if (arr.length == 1) {
			return arr;
		}

		// 分半处理
		int half = arr.length / 2;
		int[] arr1 = new int[half];
		int[] arr2 = new int[arr.length - half];

		System.arraycopy(arr, 0, arr1, 0, arr1.length);
		System.arraycopy(arr, half, arr2, 0, arr2.length);

		// 递归部分
		arr1 = mergeSort(arr1);
		arr2 = mergeSort(arr2);

		return mergeSortSub(arr1, arr2);
	}
	//归并排序子程序
	public static int[] mergeSortSub(int[] arr1, int[] arr2) {
		int[] result = new int[arr1.length + arr2.length];
		int i = 0, j = 0, k = 0;
		while (true) {
			if (arr1[i] < arr2[j]) {
				result[k] = arr1[i];
				if (++i > arr1.length - 1) {
					break;
				}
			} else {
				result[k] = arr2[j];
				if (++j > arr2.length - 1) {
					break;
				}
			}
			k++;
		}

		for (; i < arr1.length; i++) {
			result[++k] = arr1[i];
		}
		for (; j < arr2.length; j++) {
			result[++k] = arr2[j];
		}
		return result;
	}

}


使用冒泡排序法,我没有完整让它运行完毕,因为实在是太慢了。我尝试换成1K个数据,用了数分钟。


而下面是使用归并排序法,加上将所有数据输出,也只花了3秒不到时间。



真是算法拯救了人类。。

资源下载链接为: https://pan.quark.cn/s/22ca96b7bd39 在当今的软件开发领域,自动化构建与发布是提升开发效率项目质量的关键环节。Jenkins Pipeline作为一种强大的自动化工具,能够有效助力Java项目的快速构建、测试及部署。本文将详细介绍如何利用Jenkins Pipeline实现Java项目的自动化构建与发布。 Jenkins Pipeline简介 Jenkins Pipeline是运行在Jenkins上的一套工作流框架,它将原本分散在单个或多个节点上独立运行的任务串联起来,实现复杂流程的编排与可视化。它是Jenkins 2.X的核心特性之一,推动了Jenkins从持续集成(CI)向持续交付(CD)及DevOps的转变。 创建Pipeline项目 要使用Jenkins Pipeline自动化构建发布Java项目,首先需要创建Pipeline项目。具体步骤如下: 登录Jenkins,点击“新建项”,选择“Pipeline”。 输入项目名称描述,点击“确定”。 在Pipeline脚本中定义项目字典、发版脚本预发布脚本。 编写Pipeline脚本 Pipeline脚本是Jenkins Pipeline的核心,用于定义自动化构建发布的流程。以下是一个简单的Pipeline脚本示例: 在上述脚本中,定义了四个阶段:Checkout、Build、Push packageDeploy/Rollback。每个阶段都可以根据实际需求进行配置调整。 通过Jenkins Pipeline自动化构建发布Java项目,可以显著提升开发效率项目质量。借助Pipeline,我们能够轻松实现自动化构建、测试部署,从而提高项目的整体质量可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值