天天干天天操天天爱-天天干天天操天天操-天天干天天操天天插-天天干天天操天天干-天天干天天操天天摸

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

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.

主站蜘蛛池模板: 欧美亚洲国产成人综合在线 | 嫩草视频网站 | 欧美色欧美亚洲高清在线视频 | 正在播放国产精品白丝在线 | 麻豆污视频 | 91国内精品久久久久怡红院 | 欧美成人看片黄a免费 | 欧美精品二区 | 亚洲午夜久久久久影院 | 99久久99 | 精品国产综合 | 男女做a一级视频免费观看 男女喷水视频 | 大陆一级毛片免费视频观看 | 亚洲国产乱 | 美国三级毛片 | 久久精品免费 | 免费在线影院 | a级毛片免费 | 深夜国产在线 | 国产美女一区二区在线观看 | 伊人精品网| 成人影院午夜久久影院 | 国产成人精品视频频 | bbixx在线观看 | 国产黄大片在线观看视频 | 91污污视频 | 欧美一级二级三级视频 | 久久精品网站免费观看 | 黄色一级毛片网站 | 天天躁夜夜躁很很躁2020 | 亚洲另类在线观看 | 一区二区三区无码高清视频 | 日本黄色片一级片 | 亚洲高清heyzo加勒比 | 欧美日韩亚洲综合另类ac | 亚洲综合色网站 | 1024国产精品视频观看 | 欧洲亚洲欧美国产日本高清 | 特黄一级片 | 国产香蕉91tv永久在线 | 欧美黄色一级大片 |