課程目錄: 計算機科學:有目的的編程培訓

4401 人關注
(78637/99817)
課程大綱:

計算機科學:有目的的編程培訓

 

 

BASIC PROGRAMMING CONCEPTS

Why program? This lecture addresses that basic question.

Then it describes the anatomy of your first program and the process of developing a program

in Java using either virtual terminals or a program development environment, with some historical context.

Most of the lecture is devoted to a thorough coverage of Java's built-in data types, with example programs for each.

CONDITIONALS AND LOOPS

The if, while, and for statements are Java's fundamental control structures.

This lecture is built around short programs that use these constructs to address important computational tasks.

Examples include sorting, computing the square root, factoring, and simulating a random process.

The lecture concludes with a detailed example illustrating the process of debugging a program.

 

ARRAYS

Computing with a large sequence of values of the same type is extremely common.

This lecture describes Java's built-in array data structure that supports such applications,

with several examples, including shuffling a deck of cards,

the coupon collector test for randomness, and random walks in a grid.

 

INPUT AND OUTPUT

 

To interact with our programs,

we need mechanisms for taking information from the outside world and for presenting information

to the outside world. This lecture describes several such mechanisms: for text, drawings, and animation.

Detailed examples covered include fractal drawings that model natural phenomena and

an animation of a ball bouncing around in the display window.

FUNCTIONS AND LIBRARIES

 

Modular programming is the art and science of breaking

a program into pieces that can be individually developed.

This lecture introduces functions (Java methods), a fundamental mechanism that enables modular programming.

Motivating examples include functions for the classic Gaussian distribution and an application that creates digital music.

 

RECURSION

A recursive function is one that calls itself.

This lecture introduces the concept by treating

in detail the ruler function and (related) classic examples, including the Towers of Hanoi puzzle,

the H-tree, and simple models of the real world based on recursion. We show a common pitfall

in the use of recursion, and a simple way to avoid it, which introduces

a different (related) programming paradigm known as dynamic programming.

 

PERFORMANCE

 

When you develop a program,

you need to be aware of its resource requirements.

In this lecture, we describe a scientific approach to understanding performance,

where we develop mathematical models describing

the running time our programs and then run empirical tests

to validate them. Eventually we come to a simple and effective approach that you can use

to predict the running time of your own programs that involve significant amounts of computation.

ABSTRACT DATA TYPES

In Java, you can create your own data types and use them

in your programs. In this and the next lecture, we show how this ability allows us

to view our programs as abstract representations of real-world concepts.

First we show the mechanics of writing client programs that use data types.

Our examples involve abstractions such as color, images, and genes. This style

of programming is known as object-oriented programming because

our programs manipulate objects, which hold data type values.

CREATING DATA TYPES

Creating your own data types is the central activity

in modern Java programming. This lecture covers the mechanics (instance variables,

constructors, instance methods, and test clients) and then develops several examples,

culminating in a program that uses a quintessential mathematical

abstraction (complex numbers) to create visual representations of the famous Mandelbrot set.

PROGRAMMING LANGUAGES

We conclude the course with an overview of important issues surrounding programming languages.

To convince you that your knowledge of Java will enable you to learn other programming languages,

we show implementations of a typical program in C, C++, Python, and Matlab.

We describe important differences among these languages and address fundamental issues,

such as garbage collection, type checking, object oriented programming,

and functional programming with some brief historical context.

主站蜘蛛池模板: www.狠狠插| 亚洲综合视频在线观看| 久久99精品久久久久子伦| 国产精品入口麻豆免费观看| 欧美午夜理伦三级理论三级| 国产麻豆精品一区二区三区V视界 国产麻豆精品久久一二三 | 女人双腿搬开让男人桶| 六月丁香婷婷天天在线| 亚洲av无码专区在线观看成人| 2019中文字幕无线乱码| 欧美成人免费全部观看在线看| 成人性生活免费看| 国产成人yy免费视频| 亚洲第一页视频| 中国女人内谢69xxx| 美女舒服好紧太爽了视频| 日韩在线视频精品| 国产精品黄页网站在线播放免费| 午夜精品久久久久久中宇| 一级毛片无遮挡免费全部| 艹逼视频免费看| 最近最新中文字幕免费的一页 | 国产九九久久99精品影院| 久久久久成人片免费观看蜜芽| 亚洲国产激情在线一区| 欧美黑人巨大xxxxxxxx| 国产精品无码翘臀在线观看| 免费**毛片在线搐放正片| 99热精品久久只有精品| 精品久久久久久无码中文野结衣| 日日夜夜天天久久| 国产欧美在线视频免费| 久久夜色撩人精品国产| 美女的尿口免费| 女人18水真多毛片免费观看| 亚洲欧美精品中文字幕| 99久热只有精品视频免费观看17| 欧美激情第1页| 国产色秀视频在线观看| 亚洲第一成年免费网站| 日本一二三精品黑人区|