关于《Algorithms 4》

2020-10-27 21:19:17 +08:00
 zhuyongqi9

今天拜读了算法红宝书,感觉这样的一个排序的模版让我想,一辈子都想不出来,功能都能实现,但是写不出这样的方法

public class Example {
    public static void sort(Comparable[] a){

    }

    private static boolean less(Comparable v,Comparable w)
    { return v.compareTo(w)<0;}

    private static void exch(Comparable[] a,int i,int j)
    { Comparable t=a[i];a[i]=a[j];a[j]=t; }

    private static void show(Comparable[] a){
        for (int i = 0; i < a.length; i++)
            StdOut.print(a[i]+" ");
        StdOut.println();
    }

    public static boolean isSorted(Comparable[] a){//检查数组是否有序
        for(int i=1;i<a.length;i++)
            if(less(a[i],a[i-1])) return false;
        return true;
    }

    public static void main(String args[]){
        String[] a= StdIn.readAllStrings();
        sort(a);
        assert isSorted(a);//若数组被成功排序,则继续执行
        show(a);
    }

}


2301 次点击
所在节点    Java
7 条回复
zxCoder
2020-10-27 21:40:20 +08:00
下次就能写出来了
traviszhou
2020-10-28 01:12:31 +08:00
变成抽象类,直接重写 sort() 方法
hoyixi
2020-10-28 02:03:58 +08:00
这和算法无关,想不到这么写,说明还没有熟练掌握一门面向对象的(静态)编程语言
lululau
2020-10-28 09:11:08 +08:00
学算法的本质就是背诵啊,然后能结合在一起解决问题,你以为学了算法就能自己发明新算法了吗,那不是看本书就能成计算机科学家了
liujavamail
2020-10-28 09:37:23 +08:00
算法,就是解决某个问题的方法,都是人想出来的,牛的人想出来了, 你用就行了,就像物理数学上的那些定理,我们发现不了,但不妨碍我们去使用
azcvcza
2020-10-28 09:44:44 +08:00
题主的意思不是说算法写不出,而是各个功能没有抽象隔离得那么细
liujavamail
2020-10-28 09:55:53 +08:00
好吧,看错了,不过可以看下代码整洁之道,应该会有相关的收获

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/719191

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX