仓酷云

标题: 发布一篇java中完成希尔排序算法 [打印本页]

作者: 透明    时间: 2015-1-18 11:34
标题: 发布一篇java中完成希尔排序算法
J2ME在手机游戏开发的作用也是无用质疑的。至于桌面程序,可能有人说java不行,界面不好看,但是请看看net网页编程Beans和Eclipse吧,他们都是利用java开发的,而他们的界面是多么的华丽,所以界面决不是java的缺点。还有一个不得不提的优点就是大多java人员都挂在嘴边的java的跨平台性,目前这确实也是java优点之一。
packageUtils.Sort;
/**

*希尔排序,请求待排序的数组必需完成Comparable接口

*/

publicclassShellSortimplementsSortStrategy

{

privateint[]increment;
/**

*使用希尔排序算法对数组obj举行排序

*/

publicvoidsort(Comparable[]obj)

{

if(obj==null)

{

thrownewNullPointerException("Theargumentcannotbenull!");

}

//初始化步长

initGap(obj);

//步长顺次变更(递加)

for(inti=increment.length-1;i>=0;i--)

{

intstep=increment[i];

//由步长地位入手下手

for(intj=step;j<obj.length;j++)

{

Comparabletmp;

//假如前面的小于后面的(相隔step),则与后面的互换

for(intm=j;m>=step;m=m-step)

{

if(obj[m].compareTo(obj[m-step])<0)

{

tmp=obj[m-step];

obj[m-step]=obj[m];

obj[m]=tmp;

}
//由于之前的地位一定已对照过,以是这里间接加入轮回

else

{

break;

}

}

}

}

}

/**

*依据数组的长度断定求增量的公式的最年夜指数,公式为pow(4,i)-3*pow(2,i)+1和9*pow(4,i)-9*pow

2,i)+1

*@returnint[]两个公式的最年夜指数

*@paramlength数组的长度

*/

privateint[]initExponent(intlength)

{

int[]exp=newint[2];

exp[0]=1;

exp[1]=-1;

int[]gap=newint[2];

gap[0]=gap[1]=0;

//断定两个公式的最年夜指数

while(gap[0]<length)

{

exp[0]++;

gap[0]=(int)(Math.pow(4,exp[0])-3*Math.pow(2,exp[0])+1);

}

exp[0]--;

while(gap[1]<length)

{

exp[1]++;

gap[1]=(int)(9*Math.pow(4,exp[1])-9*Math.pow(2,exp[1])+1);

}

exp[1]--;

returnexp;

}
privatevoidinitGap(Comparable[]obj)

{

//使用公式初始化增量序列

intexp[]=initExponent(obj.length);

int[]gap=newint[2];

increment=newint[exp[0]+exp[1]];

//将增量数组由年夜到小赋值

for(inti=exp[0]+exp[1]-1;i>=0;i--)

{

gap[0]=(int)(Math.pow(4,exp[0])-3*Math.pow(2,exp[0])+1);

gap[1]=(int)(9*Math.pow(4,exp[1])-9*Math.pow(2,exp[1])+1);

//将年夜的增量先放进增量数组,这里实践上是一个合并排序

//不必要思索gap[0]==gap[1]的情形,由于不成能呈现相称。

if(gap[0]>gap[1])

{

increment[i]=gap[0];

exp[0]--;

}

else

{

increment[i]=gap[1];

exp[1]--;

}

}

}

}

C#是盗用了Java的源代码,仿照开发的,原因是Java是开源的啊,盗了也白盗,还有一点,开发C#语言的团队是就是开发Java语言的团队,是微软重金挖过去的啊
作者: 莫相离    时间: 2015-1-30 14:58
设计模式是高级程序员真正掌握面向对象核心思想的必修课。设计模式并不是一种具体"技术",它讲述的是思想,它不仅仅展示了接口或抽象类在实际案例中的灵活应用和智慧
作者: 若相依    时间: 2015-2-6 13:32
一直感觉JAVA很大,很杂,找不到学习方向,前两天在网上找到了这篇文章,感觉不错,给没有方向的我指了一个方向,先不管对不对,做下来再说。
作者: 兰色精灵    时间: 2015-2-16 07:14
是一种突破用户端机器环境和CPU
作者: 飘飘悠悠    时间: 2015-3-5 01:03
科学超级计算机、移动电话和互联网,同时拥有全球最大的开发者专业社群。
作者: 精灵巫婆    时间: 2015-3-8 17:20
我大二,Java也只学了一年,觉得还是看thinking in java好,有能力的话看英文原版(中文版翻的不怎么好),还能提高英文文档阅读能力。
作者: 透明    时间: 2015-3-16 07:39
是一种将安全性(Security)列为第一优先考虑的语言
作者: 若天明    时间: 2015-3-22 21:09
任职于太阳微系统的詹姆斯·高斯林等人于1990年代初开发Java语言的雏形,最初被命名为Oak,目标设置在家用电器等小型系统的程序语言
作者: 小魔女    时间: 2015-3-25 03:44
任职于太阳微系统的詹姆斯·高斯林等人于1990年代初开发Java语言的雏形,最初被命名为Oak,目标设置在家用电器等小型系统的程序语言
作者: 金色的骷髅    时间: 2015-4-1 00:37
是一种使网页(Web Page)由静态(Static)转变为动态(Dynamic)的语言
作者: 海妖    时间: 2015-4-13 08:26
Java 不同于一般的编译执行计算机语言和解释执行计算机语言。它首先将源代码编译成二进制字节码(bytecode),然后依赖各种不同平台上的虚拟机来解释执行字节码。从而实现了“一次编译、到处执行”的跨平台特性。
作者: 柔情似水    时间: 2015-4-23 03:34
如果要向java web方向发展也要吧看看《Java web从入门到精通》学完再到《Struts2.0入门到精通》这样你差不多就把代码给学完了。有兴趣可以看一些设计模块和框架的包等等。
作者: 蒙在股里    时间: 2015-5-4 11:35
那么我书也看了,程序也做了,别人问我的问题我都能解决了,是不是就成为高手了呢?当然没那么简单,这只是万里长征走完了第一步。不信?那你出去接一个项目,你知道怎么下手吗,你知道怎么设计吗,你知道怎么组织人员进行开发吗?你现在脑子里除了一些散乱的代码之外,可能再没有别的东西了吧!
作者: 老尸    时间: 2015-6-13 13:45
学Java必读的两个开源程序就是Jive和Pet Store.。 Jive是国外一个非常著名的BBS程序,完全开放源码。论坛的设计采用了很多先进的技术,如Cache、用户认证、Filter、XML等,而且论坛完全屏蔽了对数据库的访问,可以很轻易的在不同数据库中移植。论坛还有方便的安装和管理程序,这是我们平时编程时容易忽略的一部份(中国程序员一般只注重编程的技术含量,却完全不考虑用户的感受,这就是我们与国外软件的差距所在)。
作者: 再见西城    时间: 2015-6-14 20:20
任职于太阳微系统的詹姆斯·高斯林等人于1990年代初开发Java语言的雏形,最初被命名为Oak,目标设置在家用电器等小型系统的程序语言
作者: 第二个灵魂    时间: 2015-6-29 20:54
你可以去承接一些项目做了,一开始可能有些困难,可是你有技术积累,又考虑周全,接下项目来可以迅速作完,相信大家以后都会来找你的,所以Money就哗啦啦的。。。。。。
作者: 愤怒的大鸟    时间: 2015-7-4 01:23
应用在电视机、电话、闹钟、烤面包机等家用电器的控制和通信。由于这些智能化家电的市场需求没有预期的高,Sun公司放弃了该项计划。随着1990年代互联网的发展
作者: 不帅    时间: 2015-7-10 03:02
Java是一个纯的面向对象的程序设计语言,它继承了 C++语言面向对象技术的核心。Java舍弃了C ++语言中容易引起错误的指针(以引用取代)、运算符重载(operator overloading)
作者: 分手快乐    时间: 2015-7-17 22:34
Java自面世后就非常流行,发展迅速,对C++语言形成了有力冲击。Java 技术具有卓越的通用性、高效性、平台移植性和安全性,广泛应用于个人PC、数据中心、游戏控制台




欢迎光临 仓酷云 (http://ckuyun.com/) Powered by Discuz! X3.2