alg4th-1.1

[TOC]

algorithm 4th笔记(1.1)

第一章知识点

第一章整体结构图

二分查找

前提:数组有序
BinarySearch.java

import edu.princeton.cs.algs4.In;
import edu.princeton.cs.algs4.StdIn;
import edu.princeton.cs.algs4.StdOut;
import java.util.Arrays;

public class BinarySearch {
    public static int rank(int key, int[] a) {
        int lo = 0;
        int hi = a.length - 1;
        while (lo <= hi) {
            int mid = lo + (hi - lo) / 2;
            if (key < a[mid]) hi = mid - 1;
            else if (key > a[mid]) lo = mid + 1;
            else return mid;
        }
        return -1;
    }

    public static void main(String[] args) {
        int[] whitelist= In.readInts(args[0]);
        Arrays.sort(whitelist);
        while(!StdIn.isEmpty()){
            int key = StdIn.readInt();
            if(rank(key,whitelist) == -1){
                StdOut.println(key);
            }
        }
    }
}
  • stdlib.jar 下载
  • alg4.jar 下载
  • 运行此程序的步骤:
  • 运行程序(为了方便,把BinarySearch.java 、largeW.txt 、largeT.txt放在同一个目录)
    • 编译
javac -Djava.ext.dirs=E:\code\javacode\alg4th BinarySearch.java
    • 运行
java -Djava.ext.dirs=E:\code\javacode\alg4th -cp ./ BinarySearch tinyW.txt < tinyT.txt

注意:关于-Djava.ext.dirs参考
初学Java的人经常遇到的一个问题是:如果一个程序依赖某个文件夹下的一堆jar包,那么启动它的时候就需要在java -cp参数后面一个一个的加上jar包的名称,很不方便。比如主程序类叫Main,在目录lib下有aaa.jar,bbb.jar,ccc.jar,则需要输入以下命令才能执行 (linux系统下用冒号,windows下用分号):

java -cp lib/aaa.jar;lib/bbb.jar;/lib.ccc.jar  Main

如果jar包少,倒也不是很麻烦,但如果依赖的jar包数量很多的话,一个个的输就比较麻烦了,当然我们也可以借助一些脚本或者Ant来实现自动化,但总觉得杀鸡焉用牛刀,反而把事情弄麻烦了。我自己是这样解决的:

java -Djava.ext.dirs=./lib -cp ./bin Main    (假设主程序类Mian.class放在bin目录下)

说明:
BinarySearch 从largeW.txt中读入数据,存入whitelist数组中,然后将largeT.txt的数字重定向到控制台。
先把largeW.txt中的数排序,然后用二分查找,找出largeT.txt中的数字是否存在largeW.txt中,不存在就输出。

在Java程序中创建一个数组需要三步:

  • 声明数组的名字和类型;
  • 创建数组;
  • 初始化数组元素。

典型的数组处理代码,典型的静态方法实现

/*
** 典型的数组处理代码
*/
//求数组的最大值
public double findMaxFromDoubleArray(double[] a) {
    double max = a[0];
    for (int i = 1; i < a.length; i++) {
        if (a[i] > max) max = a[i];
    }
    return max;
}
//计算数组元素的平均值
public double calcAvg(double[] arr){
    int N=arr.length;
    double sum = 0.0;
    for(int i=0;i<N;i++){
        sum+=arr[i];
    }
    return sum/N;
}
//复制数组
public double[] copyArray(double[] arr){
    int N=arr.length;
    double[] b=new double[N];
    for(int i=0;i<N;i++){
        b[i]=arr[i];
    }
    return b;
}
//颠倒数组元素的顺序
public double[] reverseArray(double[] arr){
    int N=arr.length;
    for(int i=0;i<N/2;i++){
        double tmp=arr[i];
        arr[i]=arr[N-i-1];
        arr[N-i-1]=tmp;
    }
    return arr;
}
//矩阵相乘
public double[][] mul(double[][] a,double[][] b){
    int N=a.length;
    double[][] c=new double[N][N];
    for(int i=0;i<N;i++){
        for(int j=0;j<N;j++){
            for(int k=0;k<N;k++){
                c[i][j]=a[i][k]*b[k][j];
            }
        }
    }
    return c;
}
/*
 *典型静态方法实现
 */
//计算一个整数的绝对值
public static int abs(int x){
    if(x<0) return -x;
    else return x;
}
//计算一个浮点数的绝对值
public static double abs(double x){
    if(x<0.0) return -x;
    else return x;
}
//判断一个数是否为负数
public static boolean isPrime(int N){
    if(N<2) return false;
    for(int i=2;i*i<N;i++){
        if(N%i==0) return false;
    }
    return true;
}
//计算平方根(牛顿迭代法)
public static double sqrt(double c){
    if(c<0) return Double.NaN;
    double err=1e-15;
    double t=c;
    while(Math.abs(t-c/t)>err*t){
        t=(c/t+t)/2.0;
    }
    return t;
}
//计算直角三角形的斜边
public static double hypotenuse(double a,double b){
    return Math.sqrt(a*a+b*b);
}
//计算调和级数
public static double H(int N){
    double sum = 0.0;
    for(int i=1;i<=N;i++){
        sum+=1.0/i;
    }
    return sum;
}

编写递归代码时最重要的有以下三点:

  • 递归总有一个最简单的情况---方法的第一条语句总是一个包含return的条件语句。
  • 递归调用总是去尝试解决一个规模更小的子问题,这样递归才能收敛到最简单的情况。在下面的代码中,第四个参数和第三个参数的差值一直在缩小。
  • 递归调用的父问题和尝试解决的子问题之间不应该有交集。在下面的代码中,有个子问题个字操作的数组部分是不同的。
public static int rank(int key, int[] a) {
    return rank(key, a, 0, a.length - 1);
}

public static int rank(int key, int[] a, int lo, int hi) {
    //
    if (lo > hi) return -1;
    int mid = lo + (hi - lo) / 2;
    if (key < a[mid]) return rank(key, a, lo, mid - 1);
    else if (key > a[mid]) return rank(key, a, mid + 1, hi);
    else return mid;
} 

使用 Idea运行程序

    private static String[] readDataFromFile(String fileName) throws Exception {
        /*
         *从data.in中读取数据,然后把数据转换成Integer(包装了有Comparable接口)
         */
        URL url = Merge2.class.getClassLoader().getResource(fileName);
        File file = new File(url.getPath());
        Scanner sc = new Scanner(file);

        String str = sc.nextLine();
        return str.split(" ");
    }

在主函数中读取只需要使用:

String[] ss = readDataFromFile("ch02/tiny.txt");

注意:

  1. 需要在maven工程中,resources文件夹下,新建一个和要运行的类同样的目录存放要读入的文件。
  2. idea中选择运行方式为Debug方式。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,335评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,895评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,766评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,918评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,042评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,169评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,219评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,976评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,393评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,711评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,876评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,562评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,193评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,903评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,699评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,764评论 2 351

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,644评论 18 139
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,605评论 18 399
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,900评论 25 707
  • 文字只是记录自己生活的一种直接方式
    米妮酷阅读 139评论 0 0
  • 和室友终于约到了一回户外活动,心情难免激动。5月6号这天7:30,我从学校(工商学院)出发,坐820路到鼓楼,与...
    Pamlolo阅读 322评论 0 0