4190.210 Principles of Programming
°ÀÇ: ¿ù 16:00-17:45 @ 302µ¿ 208È£
½Ç½À: ¼ö 16:00-17:45 @ 302µ¿ 311-1È£
  
-
´É·Â. ÀÌ °ÀÇ´Â ÇлýµéÀÌ ÇÁ·Î±×·¥ ÀÛ¼ºÀÇ ±âº» ¿ø¸®, ±¸¼º ¿ä¼Ò,
ÇÁ·Î±×·¡¹Ö ¹ÌÇеîÀ» ½ÀµæÇÏ°Ô ÇÔÀ¸·Î½á, ¼ÒÇÁÆ®¿þ¾î ½Ã½ºÅÛÀÌ µå·¯³»´Â
º¹À⼺À» ¼Õ½±°Ô ´Ù·ê ¼ö ÀÖ´Â ´É·Â°ú ÀڽۨÀ» ÀÍÈ÷°Ô ÇÑ´Ù.
-
º¸Æí. ÀÌ °ÀÇ¿¡¼ ÀÍÈù ³»¿ëÀº ÀåÂ÷ ¾î¶² ¾ð¾î¸¦ »ç¿ëÇÏ¿©
¼ÒÇÁÆ®¿þ¾î¸¦ ÀÛ¼ºÇÏ´õ¶óµµ À¯¿ëÇϰԵȴÙ. ÀÌ
°ÀÇ´Â Çлýµé¿¡°Ô ƯÁ¤ ¾ð¾î¸¦ °¡¸£Ä¡´Â °ú¸ñ(training)ÀÌ ¾Æ´Ï´Ù. ¸í·áÇÏ°í
È¿°úÀûÀ¸·Î »ý°¢ÇÒ ¼ö ÀÖ°Ô ÇÏ´Â ÇÁ·Î±×·¡¹Ö ±³À°(education)À» ¸ñÇ¥·ÎÇÑ´Ù.
-
´«³ôÀÌ. ÀÌ °ÀÇ´Â ÇÁ·Î±×·¡¹Ö ±â¼úÀÇ ÇöÀç»Ó ¾Æ´Ï¶ó ¾ÕÀ¸·Î ³ªÅ¸³¯ ¹Ì·¡¿¡ ´ëÇÑ
´«³ôÀ̸¦ °®Ãßµµ·Ï ÇÑ´Ù. ÇÁ·Î±×·¡¹ÖÀº Á¡Á¡ »óÀ§ÀÇ ·¹º§¿¡¼ ÀÌ·ç¾îÁö°í ÀÖ´Ù.
ÇÁ·Î±×·¥ÀÌ ±â°è¸¦ »ç¿ëÇϱâ À§ÇÑ µµ±¸¶ó´Â ½Ã°¢°ú ÇÔ²² ±â°è°¡ ÇÁ·Î±×·¥
½ÇÇàÀ» À§ÇÑ µµ±¸¶ó´Â ½Ã°¢À» °®Ãßµµ·Ï ÇÑ´Ù.
´Ù·ç´Â ÅäÇÈÀº
- ±âº»ºÎÇ°°ú Á¶ÇÕ(elements & compound)
- Àç±Í¿Í ¹Ýº¹(recursion & iteration)
- ¼Ó³»¿ë °¨Ãß±â(procedural & data abstraction)
- °èÃþ±¸Á¶·Î ¼Ó³»¿ë °¨Ãß±â(modularity & hierarchy)
- ¸Â´Â ÇÁ·Î±×·¥ÀÎÁö È®ÀÎÇϱâ(program proof)
- ŸÀÔÀ¸·Î Á¤¸®+ÀÌÇØÇϱâ(types & typeful programming)
- °ªÁß½ÉÀÇ ÇÁ·Î±×·¡¹Ö(values & applicative programming)
- ¹°°ÇÁß½ÉÀÇ ÇÁ·Î±×·¡¹Ö(objects & imperative programming)
- ¿¹¿Ü»óȲ °ü¸®(exceptions & advanced control)
¼÷Á¦: 40%, µ¿·áµµ¿ò Æò°¡: 20%, ÇÁ·ÎÁ§Æ®: 30%, ½Ç½À: 10%
- ¼ºÀûÀº Àý´ëÆò°¡ÀÌ´Ù.
- ÇÁ·Î±×·¥ ¼÷Á¦°¡ º¹Á¦·Î ÆÇÁ¤µÇ¸é, ¼÷Á¦³ª ÇÁ·ÎÁ§Æ®ÀÇ ¸ðµç
Á¡¼ö°¡ 50% °¨Á¡µÈ´Ù.
- ÇÁ·Î±×·¥ º¹Á¦¿©ºÎ´Â CloneChecker¿¡
ÀÇÇØ ÀÚµ¿À¸·Î °¨º°µÈ´Ù.
- ¼÷Á¦ ½Ã°£Ç¥
- HW1: due 09/14 24:00. primitives, compound,
recursion.
- HW2: due 09/21 24:00. compound, recursion,
higher-order function.
- HW3: due 10/03 24:00. typeful programming, data
abstraction.
- HW4: due
10/12 10/15 24:00. data implementation,
termination check, Huffman encoding, SKI reactor.
- HW5: due 10/26 24:00. data abstraction with
multiple implementations, Turing machine, Challenge I.
- HW6: due 11/20 24:00. imperative/stateful
programming, automatic typeful programming I, Challenge II.
- HW7: due
11/30 12/02 24:00. automatic typeful
programming II, module programming I, Challenge III.
- HW8: due
12/07 12/09 24:00. module programming II.
- Project: due 12/21 24:00.
ÇÁ·ÎÁ§Æ® Project
- ½Ç¶óºÎ½º Syllabus
- ±³Àç(¹ø¿ª¼):
[ÄÄÇ»ÅÍ
ÇÁ·Î±×·¥ÀÇ ±¸Á¶¿Í Çؼ®], ±èÀç¿ì ¿Ü, ÀλçÀÌÆ®, 2007
- ±³Àç(¿ø¼):
Structure and Interpretation of Computer Programs(SICP),
2nd ed., Harold Abelson
and Gerald Jay
Sussman with Julie Sussman, MIT Press.
(SICP's full-text on-line)
- ½Ç½Àȯ°æ:
MIT Scheme
(or Racket)
& OCaml
- To view/print PDF files: Acrobat Reader
- °ÀÇ ½½¶óÀ̵å:
- Part 0: °ÀÇ¿ë, ¹èÆ÷¿ë(2in1, 4in1)
- Part 1: °ÀÇ¿ë, ¹èÆ÷¿ë(2in1, 4in1)
- Part 2: °ÀÇ¿ë, ¹èÆ÷¿ë(2in1, 4in1)
- Part 3: °ÀÇ¿ë, ¹èÆ÷¿ë(2in1, 4in1)
- Part 4: °ÀÇ¿ë, ¹èÆ÷¿ë(2in1, 4in1),
inductive refinement ¿¹
¿ø¸®? ¾î¶»°Ô? ¿Ö? ±×·¸´Ù¸é?
|
|