課程目錄:程序員的核心技能培訓
4401 人關注
(78637/99817)
課程大綱:

          程序員的核心技能培訓

 

 

 

Programming Competitions
We'll begin with introduction to the world of competitive programming — the rules,
specialties and helpful tips on taking part in competitions in general. In a separate lesson,
we'll learn how to test programs: what kinds of test cases there are, how to organize
the search for a bugtest, and particularly a method of automating testing called stress-testing.
CORRECTNESS FIRSTIn this module,
we'll start with the most basic things you need to actually solve algorithmic problems. First,
we'll talk about structuring your code and intuition behind it — why it's very important,
how to manage dependencies between parts of different purpose,
how intuitive rules are enforced through formal invariants and conditions.
We'll also identify a special class of solutions — brute force solutions — which are always correct,
but often very slow. And we'll learn how to estimate running time of our solutions by using a powerful concept of big-O notation.
COMMON STRUGGLESIn competitive programming,
there are a lot of things to stumble upon — if you don't know them first!
We'll delve into how numbers are represented in computers,
identify the most common issues with integer and floating point arithmetic,
and learn to overcome them. We'll also discuss how to get stuck less in general,
especially when debugging solutions.
COMMON STRUGGLES 2We
continue considering common struggles arising in competitive programming.
We start by learning how to prove that a natural greedy algorithm is correct.
We also discuss programming languages: what features are most helpful on competitions,
and what are the advantages and pitfalls of several frequently used languages.
Finally, we study an essential and easy-to-implement data structure: the segment tree.
Dynamic Programming
Dynamic programming is a powerful algorithmic paradigm with lots of applications
in areas like optimisation, scheduling, planning, bioinformatics,
and others. For this reason, it is not surprising that it is the most popular type of problems in competitive programming.
A common feature of such problems is that a solution is usually easy to implement.
This does not however mean that it is also easy to find a solution!
Therefore, it is important to practice solving such problems.
And this is exactly what we are going to do in this module!
Dynamic Programming 2We continue applying dynamic programming technique to various problems.

主站蜘蛛池模板: 久久婷婷五月综合色99啪ak| 欧美日韩亚洲综合在线| 亚洲国产婷婷综合在线精品| 久久婷婷色综合一区二区| 亚洲欧美日韩综合在线观看不卡顿| 国产成人综合久久精品尤物| heyzo专区无码综合| 五月天激情综合网丁香婷婷| 亚洲综合久久夜AV | 国产综合色在线视频区| 久久综合亚洲鲁鲁五月天| 一本色道久久88综合日韩精品| 亚洲一本综合久久| 一日本道伊人久久综合影| 狠狠色狠狠色综合曰曰| 欧美激情综合亚洲一二区| 亚洲精品第一国产综合境外资源| 狠狠色伊人亚洲综合成人| 综合欧美亚洲日本一区| 综合欧美视频一区二区三区| 亚洲精品综合一二三区在线| 亚洲精品国产第一综合99久久| 欧美伊人久久大香线蕉综合| 国产成人亚洲综合| 亚洲欧美日韩综合在线观看不卡顿| 小说区 图片区色 综合区| 久久综合狠狠综合久久97色| 亚洲色欧美色国产综合色| 国产综合成人色产三级高清在线精品发布| 天天综合久久久网| 国产香蕉久久精品综合网| 综合久久久久久中文字幕亚洲国产国产综合一区首| 激情综合婷婷丁香五月蜜桃| 久久国产综合精品五月天| 狠狠狠色丁香婷婷综合久久五月| 久久综合欧美成人| 三级韩国一区久久二区综合| 久久综合一区二区无码| 天天综合久久一二三区| 色噜噜狠狠色综合网| 中文字幕亚洲综合小综合在线|