算法基础(陈雪) 2024春 2022春  课程号:01114604
2024春 2022春  课程号:01114604
9.7(12人评价)
9.7(12人评价)
  • 课程难度:困难
  • 作业多少:很多
  • 给分好坏:超好
  • 收获大小:很多
选课类别:计划内与自由选修 教学类型:理论实验课
课程类别:本科计划内课程 开课单位:计算机科学与技术系
课程层次:专业基础   学分:3.5
课程主页:暂无(如果你知道,劳烦告诉我们!)
简介 最后更新:

在计算机科学中,算法(Algorithm)可以理解为求解问题的一个具体计算步骤。本课程主要介绍算法的基本概念,以及算法设计和分析的基本方法和技巧。课程包含了高级数据结构和算法的若干基本内容:算法分析的基本技术、排序、堆和优先队列、红黑树、平摊分析、二项堆、分离集合、分治法、动态规划、贪心法、快速傅立叶变换、图论算法、串匹配等,和典型计算问题的求解算法。

排序 学期

评分 评分 12条点评

Peanut_Tang 2024春
  • 课程难度:困难
  • 作业多少:很多
  • 给分好坏:超好
  • 收获大小:很多
  • 难度:困难
  • 作业:很多
  • 给分:超好
  • 收获:很多

当助教的时候一直胆战心惊,担心自己做的不好被挂到评课社区上,现在看来大家都是比较友好的。


我建议有信竞基础的人来先修,会有较大收获。如果是算法新手,可能强度过大,一学期下来可能体验不是特别好。

我建议有信竞基础的人来先修,会有较大收获。如果是算法新手,可能强度过大,一学期下来可能体验不是特别好。

我建议有信竞基础的人来先修,会有较大收获。如果是算法新手,可能强度过大,一学期下来可能体验不是特别好。


2024 春季学期,陈雪老师的算法基础班上有 34 位学生(原先有 36 人,最后退课了两位),配备了三位助教:一位是大四的学长,是有在助教系统审核通过的正式助教;剩下两位是大二的编外助教,其中一位是我。相比剩下两位已经参加和即将参加 ICPC World Final 的大佬,我估摸着是三位助教里最菜的。

PS:陈雪老师可以说是特别慷慨,工资给的不少。

一些正经内容:

  • 课程内容:课程简介上说的比较清楚了。总的来说,对于高中有过竞赛基础的同学来说,这门课新的东西只有计算理论初步(甚至这部分可能很多信竞生高中也有或多或少的接触)。老师额外来了一些近似和随机算法的私货。和高中竞赛相比,会更加细致、更加理论的学习这一些算法。
  • 选课建议:我建议有信竞基础的人来先修,会有较大收获。如果是算法新手,可能强度过大,一学期下来可能体验不是特别好。如果是重修的话,可以选这个班,老师奶人力度非常大。
  • 给分力度:老师非常非常奶!22 年(老师第一年上课)什么情况我不知道,但是 23 年和 24 年都是奶穿了的程度(只不过 23 年可能大家都被课程内容弄破防了,即使给分巨好也无法挽回风评)。今年改完卷子后,因为两位大二的助教还有期末考要准备,所以我就没有参与调分过程。据看着陈雪老师调分的学长说,最后给分大概是「100 - 排名」,要知道班上一共就 34 位学生。

一些杂谈:

  • 老师在期中期末都让几位助教出几道题交给他,但最后老师都没采纳几题。期中有两题是助教出的,期末则全是老师出的。
  • 大四学长那位助教改作业真的好认真!看到评分居然不是 10 或者 5 的倍数时,我惊呆了。
  • Linke OJ 今年表现不错。去年的时候,Linke OJ 是一个每天会爆炸至少一次的 OJ(估计是什么东西没处理好,评测量一上去,就会崩溃)。今年整个下来 Linke OJ 只崩溃了一次!好评!数院的算法基础课用的 OJ 系统貌似是去年 Linke OJ 用的,然后被骂惨了。
  • 今年是改卷最速传说,因为老师要赶着去招生。上午考完,中午改卷,下午开放问成绩,晚上和明天白天查卷,明天晚上提交成绩,后天早上教务处审核通过。

这部分是我给老师发的邮件:

https://www.wjx.cn/vm/Qpmr2PA.aspx

在学期结束后,我在算法基础课程的 QQ 群里,发布了一个问卷,内容可见于上面的链接。

虽然只收集到十份问卷,但介于全班也就只有不到 35 人,这份问卷或许还算有点参考价值。我进行一些总结,并结合着我自己的观点进行一些陈述:

  • 一是有小部分同学反应作业实验有一点多。虽说只是小部分,但我也有一些担忧。这学期一共有 14 次作业实验,必交有 13 次。而去年作业实验一共只有 11 次,而且最后 HW6 是交了就满分,所以实际上只有 10 次。今年的作业实验量明显增大,感觉这会给同学带来一些负担。
  • 二是像 ChatGPT 这类工具能否使用的问题,大部分都觉得可以,我们三位助教其实都有一点抵触,不知道老师你怎么想。
  • 还有就是大多数认为习题课讲义(也就是作业和实验的答案)应该公开,这个和老师目前的措施不一致。
  • 剩下就是一些杂项,比如大部分认为实验用 C/C++ 就可以。以及这学期 Linke 的 OJ 表现不错。
  • 还有一些关于实验题太过于利好有竞赛经历的人的问题,这点我们几位助教探讨过很多次,但目前都没有很好的想法解决这个问题。

这学期大家合作愉快。


除了上面问卷的问题,现在想想或许还有一些事情是我需要反思的。

  • 一个是卡常数的问题,虽然极力避免,但好像最后还是有一两题时间限制太紧(网络流模板题卡的太死了,最后我不得不删点),还都是我负责的题目。
  • 以及有限题目数据有点问题,以后也要注意。
  • 关于实验题太过于利好有竞赛经历的人的问题,有的人提到可以给出更加详细的思路,如果明年还当助教还负责实验的话,或许我会参考一下这个思路。

明年或许还会当这门课的助教,大家多多包涵。

(最后修改于 19 6 复制链接
红领巾你是助教吗?
Peanut_Tang人少就扔给学长了。
笑死
红领巾支持唐助教!
gqyg大二咋当
zjz_sgy唐助教下学期捞我!
立即登录,说说你的看法
txtxj 2022春
  • 课程难度:困难
  • 作业多少:中等
  • 给分好坏:一般
  • 收获大小:很多
  • 难度:困难
  • 作业:中等
  • 给分:一般
  • 收获:很多

上课:纯英 PPT ,但很好理解。老师经常板书证明过程,上课不听下课就不会。

作业:证明题好难,题量一般。前半学期 LaTex 居多,后半学期 OJ 居多。

考试:全开卷,不考背书,书上已有的算法可以直接在试卷上调用。考试主要考算法设计以及证明。

收获:入学以来收获最大的课。陈雪老师太强了,楼上xd说得很对,写作业、上课已经感觉到自卑了……

给分:OJ 满 + 作业 80% + 两次考试排名 35% = 总评 3.7

助教允许公开 OJ 题目,那我就贴个链接

https://github.com/txtxj/USTC-Algorithm

(最后修改于 5 0 复制链接
Gilbert 2024春
  • 课程难度:困难
  • 作业多少:中等
  • 给分好坏:超好
  • 收获大小:很多
  • 难度:困难
  • 作业:中等
  • 给分:超好
  • 收获:很多

一个学期下来被实验和作业杀穿了。没学过离散数学真实太伤了

当然收获还是很大。

可惜的是这个学期从三月底开始到现在一直都在生病,基本都没到课,期中也是生着病考的,估计2天后期末也好不起来……考完再来更。


被期末考试杀成轻度抑郁了😖虽然考前就知道复习没啥用,还是复习了,然后也果真没啥用,只是不知道老师路过的时候看着我满满一张的idk是啥感想。最后我认为:\(P=NP\)


出分了,意识到自己还是当个废物比较合适。后悔没去复旦学金融的第N天

(最后修改于 4 4 复制链接
Peanut_Tang是实验太难了吗 如果是我们之后会降低难度的/(ㄒoㄒ)/~~
snow回复 @Peanut_Tang: 以 OIer 的角度看的话,像 lab1 T2 这道题,感觉 OI 选手应该大都做过原题,但初学者很难快速明确思路并熟练运用 priority queue,甚至可能根本不知道有这样的 stl 库从而体验比较差(
红领巾可以定期进行匿名问卷调查(但不确定是否会有人捣乱)
Peanut_Tang回复 @snow: 这题应该是要自己手写堆的。然后你的意见很准确,之后会避免出这种题。(不过貌似面试你叫喜欢出这种题?)
立即登录,说说你的看法
buzhidao 2022春
  • 课程难度:困难
  • 作业多少:很多
  • 给分好坏:一般
  • 收获大小:很多
  • 难度:困难
  • 作业:很多
  • 给分:一般
  • 收获:很多

陈雪老师的存在就是为了告诉我

人和人的差距比人和狗都大!

讲课很好十分!

扣的一分是用于治疗我轻度抑郁的精神治疗费。

(最后修改于 4 4 复制链接
红领巾太真实了
buzhidao回复 @ABCDE: 抱头痛哭.jpg
gyfer每次和陈老师聊天都感觉被爆杀
SproutH能细说嘛👀
立即登录,说说你的看法
七月流火 2024春
  • 课程难度:困难
  • 作业多少:很多
  • 给分好坏:超好
  • 收获大小:很多
  • 难度:困难
  • 作业:很多
  • 给分:超好
  • 收获:很多

给分很不错,我期中期末都只拿了保底30来分,作业平均拿了80%分数,最后总评78。

本来以为要挂了,很感谢老师助教奶了一口…


话说有位助教哥哥还挺帅的,我期末时用idk遍历完题目后盯着他看了好一会。


感觉有些实验题可能需要一些算法基础,似乎对于有基础的同学是模板题,但没基础的同学很难做出来(?)

(最后修改于 3 0 复制链接
匿名用户 2022春
  • 课程难度:困难
  • 作业多少:中等
  • 给分好坏:超好
  • 收获大小:很多
  • 难度:困难
  • 作业:中等
  • 给分:超好
  • 收获:很多

吹爆老师!!!虽然平时作业确实比较难,但是就收获超多+给分超好就可以直接给满分了!

说实话有点小后悔,早知道秋季就不学算法了,不如春季学

3 0 复制链接
腕豪 2022春
  • 课程难度:困难
  • 作业多少:很多
  • 给分好坏:超好
  • 收获大小:很多
  • 难度:困难
  • 作业:很多
  • 给分:超好
  • 收获:很多

陈老师是清华姚班毕业的,水平自然没得说。这门课对计算机系的同学也比较重要,所以我写一点自己的见解供后人参考。

本人最开始是顾乃杰班上的,但因为顾老师给分太杀不得已到陈老师班上重修(我不知道为什么顾乃杰风评这么好,反正我身边至少五六个3.0及以下的)。

优点

考试开卷,除了电子产品,想带什么带什么。我觉得这一点非常好,因为学习算法本身就应该是学习算法背后的思想,从而举一反三,解决新的问题,而不应该当成文科来考(本人强烈谴责顾乃杰老师考红黑树应该如何删除和插入,这种东西别人都已经帮我们实现好了,只需要调用即可,为什么还要记住?就算记住了几天不看又会忘,不知道有什么意义)。考试的具体内容就是给几道题目,给出求解算法,伪代码或者其他形式均可(我当时不想写代码,就写了一大堆文字哈哈哈)

助教和老师都很负责。助教和老师每周都会安排固定的时间用于答疑和交流,什么问题都可以问,有一次oj的题目比较难,很多人都不会,然后助教直接在答疑的时候把算法告诉大家了。

给分好。本人期中期末都没有复习过(因为重修的原因),期中比平均分高2分,期末比平均分低2分,最后84,我愿意称之为奶王。

缺点:

作业很难(真的很难)。需要较长的时间思考(相比之下顾乃杰班上的作业全是书上原题,直接在网上能找到答案,但是去年开始顾乃杰开始布置原创的题目了,好像是因为他发现大家都在网上找答案,所以以后顾乃杰班上的作业也不会太简单了)

总体来说,很推荐选陈老师的课。

3 0 复制链接
tomorrowdawn 2022春
  • 课程难度:困难
  • 作业多少:很多
  • 给分好坏:一般
  • 收获大小:很多
  • 难度:困难
  • 作业:很多
  • 给分:一般
  • 收获:很多

先占坑,放一张期末时回忆的期中卷子。这课很难,要说能拿高分,还真没底气。但是收获很多。

/uploads/files/93c45010c1730685ab3439ea7ad26363b339bc6c.pdf

以上为期中卷子。五道选择以及五道(还是六道)大题,只回忆了最重要的两道题,不过也学到很多了。

只希望期末能考好点,比杰哥给我的高个两三档就行。NPC真整不会了(抹泪)

回忆卷中Q1有误,裁剪数组时反了。细节在于n=1的时候需要手动枚举(这似乎更像个递归思路),因为指针分布在两个数组上,无法根据位置判断哪边大哪边小。

期末考完了,寄了

 

期末回忆卷

/uploads/files/e4969330845785ac451be040f377cde62e3c42a9.pdf

 

出分了,给分好。当然如果您对分数比较敏感建议看看算法课的人数,现有的三门算法都曾给分好过,主要的变量是人数,人少则给分慷慨,人多则不拔一毛。

(最后修改于 3 1 复制链接
tomorrowdawn回复 @ABCDE: 不好意思,不可以. Slide属于老师劳动成果, 不能外传.
立即登录,说说你的看法
2024春
  • 课程难度:困难
  • 作业多少:很多
  • 给分好坏:超好
  • 收获大小:很多
  • 难度:困难
  • 作业:很多
  • 给分:超好
  • 收获:很多

辅修人,来摸摸xue算法,其实我个人以前做过一点点算法竞赛,但退役的很早,a.e 0基础(?)

算法课是从入学开始就想摸的课(点燃我的OI之魂),在2秋时时间冲突没上成,遂在2春上。

其实看评课对xue算法已经有了一点心理准备,尤其lxy班cx三段式笑话那个老哥发了一份“第一次作业”,看完之后有点想跳车的(不过好在也撑下来了。

事实上上课体验比较因人而异,我一周两节课中有一节叠课于是比较跳跃(虽然另一节也摸了好几次(这是能说的吗)),xue老师上课非常注重数学细节的证明,必要的证明都会板书一点点讲,PPT上会给出详细的思考过程,认真听课(且跟得上的话)确实很享受。

但是,尽管讲的很详细,但课程进度我觉得还是巨快!从知识覆盖面来看,上半比较基础,主要是数据结构,贪心,dp之类的;下半那是真正的冲刺,图论从最短路冲到最大流最小割然后讲数论(M-L),线性规划(simplex大法好)和字符串匹配(hash和KMP),这部分算法难度不是很轻松。最后是喜闻乐见的可解,P,NP,NPC的讨论。总之如果从听课感觉来说,还是建议掂量掂量,冷静下手。

整个学期感觉最特色的是书面作业和考试。书面作业由老师发pdf,题目都饱含老师的心意(,做起来挺折磨的,但讲究的就是对算法的理解,如何将板子迁移到稍微变动的问题上面(魔改算法),确实理解下来受益匪浅。

期中考试因为没有大算法的内容,主要是各凭本事(?),用hash,贪心,dp,排序啥的一通搞,班上均分64,在已知班上巨多OI大神的情况下算是合理的。期末考试主要是针对学的算法的考察,很多题都有比较明显的算法对应,但写不写的出来嘛…均分50+,感觉同学们做的可能都不是很理想。个人特别喜欢的是期中的最后一题(分数的排序)和期末的最后一题(数论),感觉是属于令我眼前一亮的题目,非常有意思,在我的考场学习法中带来的很大的乐趣(虽然我至今仍不会做)。

这学期的1+2位助教都很好,答疑和习题课准备都很充分,OJ也没炸,除了某助教卡常自爆卡车然后删点(乐),体验都非常好,各位辛苦了!


以下是辅修xue算法的建议:最好(基本必要)有算法基础,但不用多。作业有空的话尽量做,如果觉得做作业没啥意思而且很痛苦,那建议趁前两周换个班,省的折磨自己(后面越来越难),实验反而相对而言朴素一点,而且是分点评测,可以合pian理fen取da舍fa,老师PPT会有板子的清晰伪代码。平时分拿个保底,考试就当成享受就行,如果想分数好看,不要相信自己(本人惨痛教训),期中看前面时间复杂度分析内容+排序+贪心+dp,期末其实只用看好N,NP,NPC感觉就差不多了(?),再多就是图论算法建议熟练掌握各种最短路算法之间的应用场景区别,一定只写自己非常非常有把握的,然后在卷子上疯狂默写魔法咒语即可。

算法不上cx,就像玩二游不玩原神!

你们只用在考场上抓耳挠腮,而xue老师捞人要考虑的可就多了)

2 0 复制链接
snow 2024春
  • 课程难度:困难
  • 作业多少:很多
  • 给分好坏:超好
  • 收获大小:很多
  • 难度:困难
  • 作业:很多
  • 给分:超好
  • 收获:很多

对着另一位同学的回忆版题目把自己会的简单写了写。

期末解答极简不完全版.pdf


给分挺好的,期末只有 70 多的情况下总评 96。


期末平均分 53 分,看来大家做的都不太好。。。

下午去查卷顺便跟陈老师聊了聊,他说他以为起码 DAG dp 那道题是送分题,没想到大家做的也不怎么样。。。

陈老师问了问我对这门课的一些看法什么的,也表示会考虑以后降低一些难度。他说这种难度的课在美国大概上 8-10 门就足以拿到计算机学位的证书了。他觉得这门课是他理想中的大学课程应该有的难度和样子。


这门课如果认真完成作业/实验的话,强度非常大。

本学期一共 8 次作业和 6 次实验,最后一次作业因为临近考试周可以不交。

课程内容上大概是取了剩下几个算法基础班级课程内容的并集(不过倒是没有讲可并堆,只是提了一下)且加了一些老师自己想讲的内容(例如线性规划、割问题的一些高级算法例如Karger's Algorithm、半正定规划、近似算法)。

作业和实验的难度都不小,如果没有一定基础的话完成起来会非常困难。

今年选课的人大部分都有基础,也有一定比例的辅修人(比如我)。感觉对辅修人来说,这门课想及格并不难(由于 IDK 的存在),也许可以考虑来拿个学分(


考完期中了,3个选择题+5个大题。

选择题难度不大(一题涉及Set Cover问题的近似比,可以现推)。

五个大题里面前两题难度低于作业/实验,一题为需要一点观察的贪心,一题为二维FFT(需要对FFT较为熟悉才能做),一题为对分数进行O(n)的排序(考场上没做出来)。

期中均分59,中位数64,大约是把较简单的前两道大题做出来,剩下的题目写 IDK。

期中考试.pdf

(最后修改于 2 6 复制链接
Peanut_Tang快速幂上课讲过
Peanut_Tang期中贪心题有要求时间复杂度的,不是O(nlogn)的大概是14分。
Grand_Dawn回复 @Peanut_Tang: 有时间复杂度要求怎么不写啊
Grand_Dawn回复 @Peanut_Tang: 我看没有时间复杂度要求就写了个n^2的
Peanut_Tang选择题答案错了
snow回复 @Peanut_Tang: 看助教发挥了/doge
立即登录,说说你的看法
匿名用户 2024春
  • 课程难度:困难
  • 作业多少:很多
  • 给分好坏:超好
  • 收获大小:一般
  • 难度:困难
  • 作业:很多
  • 给分:超好
  • 收获:一般

没有算法基础的同学不要来!

这门课上课会花大篇幅的时间去讲一些证明,怎么实际操作和应用会讲的比较少,而证明是建立在理解算法运行方式的基础上的,因此有可能你还没彻底搞懂算法是什么,然后证明就开始了,会听的有些吃力。

而且作业实验也是很难(也一方面是因为课上不太讲实操),拿动态规划来说,没有算法基础看半天想不出来怎么规划,有算法基础的几分钟甚至几秒内就能出思路了。(我这种纯菜鸟,做实验都是4~8个小时起步,还不一定做得对,总有不过的数据集)

不过老师给分很好,按总评构成方式算我感觉及格不了,最后老师捞到3.3🙏🏻。

0 0 复制链接

陈雪

教师主页: 戳这里

其他老师的「算法基础」课

徐云 8.2 (24) 2024秋 2023秋...
顾乃杰 7.3 (52) 2024秋 2023秋...
张举勇 7.2 (23) 2024春 2023春...
李向阳, 谈海生 7.1 (44) 2024秋 2023秋...
庄连生 4.8 (4) 2019春 2018春...
陈雪, 邵帅 5.1 (16) 2023春
未知 2022春 2016秋...
吕敏 2016春 2012春...
周世哲 2015春 2014春...

陈雪老师的其他课

计算机数学 7.0 (3) 2024春 2023春...
高级算法设计与分析 6.0 (2) 2024秋 2023秋...
算法基础 5.1 (16) 2023春