数据结构基础1

1.何为常数时间的操作?
2.如何确定算法流程的时间复杂度?
3.如何确定算法流程的总操作数量与样本数量之间的表达式关系?
4.常见的时间复杂度
5.认识异或运算
6.为什么要手撸数据结构算法?

1.何为常数时间的操作?

如果一个操作的执行时间不以具体样本量为转移,每次执行时间都是固定时间。称遮掩你的操作为常数时间的操作
例如,数组取数,数组下标取数,是取固定地址的偏移量取值,取数耗时T和这个数的大小,数组下标的大小无关。
常见的常数时间操作

  • 常见的算术运算(+ , - , * , / , %等)
  • 常见的位运算(>> , >>> , << , | , & , ^ 等)
  • 赋值,比较,自增,自减操作等
  • 数组寻址操作

总之:执行时间固定的操作都是常数时间操作。
反之:执行时间不固定的操作都不是常数时间操作。

1.如何确定算法流程的时间复杂度?

当完成了表达式的建立,只要把最高阶项留下即。低阶项都去掉,高阶的系数也去掉。
记作:O(忽略掉系数的高阶项)

3.如何确定算法流程的总操作数量与样本数量之间的表达式关系?

1,想想该算法流程所处理的数据状况,要按照最差情况来。
2,把整个流程彻底拆分为一个个基本动作,保证每个动作都是常数的操作。
3,如果数据量为N,看看基本动作的数量与N是什么关系。

4.常见的时间复杂度

排名从好到差:

  • O(1)
  • O(logN)
  • O(N)
  • O(N * logN)
  • O(N^2) O(N^3) O(N^4) O(N^5) ... O(N^k)
  • O(2^N) O(3^N) O(4^N) O(5^N) O(k^N)
  • O(N!)
5.认识异或运算

同或运算:--
异或运算:可以看作是无进位的加法器。满足交换律和结合律
案例1:快速找出一个数组中个数为奇数的那个数,并返回他

/**
 * 快速找出一个数组中个数为奇数的那个数,并返回。(只有一个奇数)
 * @author Tara
 * @implNote
 */
public class Pra4 {
    public static void main(String[] args) {
        int[] arr = new int[]{5,2,3,4,5,2,3,4,5,6,2,3,4,5,1,2,3,4,5,6,4,4,2,23,4,2,1,23,4};
        int a = 0;
        for (int i=0;i<arr.length;i++){
            a^=arr[i];
        }
        System.out.println(a);
    }
}

案例2:快速取出一个数二进制最后一位1 : N & (~N + 1)

/**
 * 快速取出一个数二进制最后一位1 :  N & (~N + 1),去除的数为1,2,4,8,16,32,64,128,256,。。。。
 * 例如 24 <==>11000,要取出1000(十进制8),
 * @author Tara
 * @implNote
 */
public class Pra5 {

    public static void main(String[] args) {
        int a = 24;
        System.out.println(a & (~a+1));

        for (int i = 0; i < 500; i++) {
            int b = i;
            System.out.print((b & (~b+1))+",");
        }
    }
}

案例3:一个数组中有两种数出现了奇数次,其他数都出现了偶数次,怎么找到并打印这两种数?

/**
 * 一个数组中有两种数出现了奇数次,其他数都出现了偶数次,怎么找到并打印这两种数?
 * @author Tara
 * @implNote
 */
public class Pra6 {

    public static void main(String[] args) {

        int arr[] = new int[]{0,1,2,3,4,5,1,2,3,4,5,0,2,4,5,6};
        printOddNums(arr);
    }

    private static void printOddNums(int[] arr) {
        // 所有数做异或操作
        int eor = 0;
        for (int i = 0; i < arr.length; i++) {
            eor^=arr[i];
        }
        // 去除num左右侧的1
        int rightOne = eor & (~eor+1);

        for (int i = 0; i < arr.length; i++) {
            if ((arr[i] & rightOne) == rightOne){
                rightOne^=arr[i];
            }
        }
        System.out.println("第一个数是"+rightOne +"第二个数是"+(eor^rightOne));
    }
}

案例4:将10进制数转成二进制,找出其中有多少个1

/**
 * 将10进制数转成二进制,找出其中有多少个1
 * @author Tara
 * @implNote
 */
public class Pra7 {

    public static void main(String[] args) {
        int N = 13257423;
        findCounts(N);
    }

    private static void findCounts(int n) {
        // 计数
        int count = 0;
        //每次都抹去最后一个1
        while (n >0){
            int rithtOne = n & (~n +1);
            //抹掉最后一个1
            n^=rithtOne;
            //思考,为什么抹掉最后一个1,用异或,不用-rightOne ???  答:因为如果N为负数的时候,会出问题。
            count++;
        }
        System.out.println("有"+count);
    }
}

6.为什么要手撸数据结构算法?

1.算法与语言无关;
2.语言提供的api是有限的,当有新功能api不提供就需要改写
3.任何软件工具的底层都是基本的算法与数据结构,这个是绕不过去了。

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

推荐阅读更多精彩内容