C语言就是数据结构的基础课,比方说C就像公式,数据结构就是解题技巧,你公式都不会,学解题技巧就很难懂了,所以说C语言的基础必须学好,尤其是指针,数据结构的很多问题都要用指针解决。
数据结构的重点是研究如何组织数据之间关系,算法是解决问题的方法,但是算法是在一定的数据结构基础上完成的,首先设计好的数据结构,在此基础上再设计好、有效的简洁的算法,数据结构中也有简单的入门级的算法,只有算法的存在才能凸显数据结构的意义,只要数据结构学好了,算法分析也是水到渠成的事情了。
有人说现代程序语言都有数据结构和算法的完整实现,掌握如何使用就可以了,其实不然,排序的时候如何选择排序算法?冒泡排序,堆排序如何选择?单链表就够用了为什么还要双链表?合格的程序员是在关键的时候知道究竟使用什么样的数据结构,究竟使用那种算法。
最后说说初学着如何去学数据结构与算法。
1、常备参考书,即使不能通读,也要时时备查。
2、已有的数据结构和算法,怎样实现是末节,能理解原理、明白使用场景才是重点。
3、不必过度追求怪异算法,适用才是最好,简单才是最佳。
4、多读来源作品,多刷题(leefcode和牛客网)
5、动手去做,动手去做,动手去做,重要的事情说三遍。
希望你能在融会贯通的基础上,举一反三,来教教我怎么继续深入学习,因为我目前也卡在更高深的算法泥潭中不能自拔。