算法设计与分析基础实验报告
应用数学学院
二零一六年六月
实验一插入排序算法
一、实验性质设计
二、实验学时14学时
三、实验目的
1、掌握插入排序的方法和原理。
2、掌握java语言实现该算法的一般流程。
四、实验内容
1、数组的输入。
2、输入、输出的异常处理。
3、插入排序的算法流程。
4、运行结果的输出。
五、实验报告
Ⅰ 、算法原理
从左到右扫描有序的子数组直到遇到一个大于或小于等于A[n-1]的元素然后就把A[n-1]插在该元素的前面或后面。
插入排序基于递归思想。
Ⅱ、书中源代码
算法Ins e rtionS o rt A[0..n-1]
//用插入排序对给定数组A[0. .n-1]排序
//输入 n个可排序元素构成的一个数组A[0. .n-1]
//输出非降序排列的数组A[0. .n-1]fori←1 to n-1 dov←A[i]j←i-1while j≥0andA[j] > vdo
A[j+1]←A[j]j←j-1
A[j+1] ← v
Ⅲ、 Java算法代码import j ava.util.*;pub lic class C haru{pub lic static vo id main(String[] args) {int n=5;int a[]=new int[n];int s=a.length;int i=0, j=0,v=0;
S ys te m.o ut.pr int ln("请输入若干个数字 ");Scanner sc=new Scanner(System.in);try{while(i<s) {a[i]=sc.nextInt();i++;
}for(i=1; i<s; i++) {v=a[i];j=i- 1;while(j>=0&&a[j]>v) {a[j+1]=a[j];j--;
}a[j+1]=v;
}
S ys te m.o ut.pr int ln("插入排序结果显示 ");for(i=0; i<s; i++) {
S ys te m.o ut.pr int ln(a[i]);
}
} catch(Exceptio n es) {
S ys te m.o ut.pr int ln(e s);
}
}
}
Ⅳ、运行结果显示
图1 图2
Ⅴ、实验结论
插入排序的基本操作是键值比较A[j]>v。键值比较次数显然依赖于特定的输入在最坏的情况下插入排序与选择排序的键值比较次数是完全一致的。在最好的情况下在外部循环的每次迭代中比较次数只执行一次。插入排序的平均性能比最差性能快两倍以及遇到基本有序的数组时表现出优异的性能使得插入排序领先与选择排序和冒泡排序。
TmhHost 商家是一家成立于2019年的国人主机品牌。目前主营的是美国VPS以及美国、香港、韩国、菲律宾的独立服务器等,其中VPS业务涵盖香港CN2、香港NTT、美国CN2回程高防、美国CN2 GIA、日本软银、韩国cn2等,均为亚太中国直连优质线路,TmhHost提供全中文界面,支持支付宝付款。 TmhHost黑五优惠活动发布了,全场云服务器、独立服务器提供8折,另有充值返现、特价服务器促销...
恒创科技也有暑期的活动,其中香港服务器也有一定折扣,当然是针对新用户的,如果我们还没有注册过或者可以有办法注册到新用户的,可以买他们家的香港服务器活动价格,2M带宽香港云服务器317元。对于一般用途还是够用的。 活动链接:恒创暑期活动爆款活动均是针对新用户的。1、云服务器仅限首次购买恒创科技产品的新用户。1 核 1G 实例规格,单个账户限购 1台;其他活动机型,单个账户限购 3 台(必须在一个订单...
如何低价香港服务器购买?想要做一个个人博客,想用香港服务器,避免繁琐备案,性能不需要多高,只是记录一些日常而已,也没啥视频之类的东西,想问问各位大佬有没有低价的香港服务器推荐?香港距大陆近,相比美国服务器最大的优势在于延迟低,ping值低,但是带宽紧张,普遍都是1M,一般戏称其为“毛细血管”。同时价格普遍高,优质稳定的一般价格不菲。大厂云梯队阿里云、腾讯云两家都有香港服务器,要注意的是尽量不要选择...