0  390076  390084  390090  390094  390100  390102  390106  390112  390114  390120  390126  390130  390132  390136  390142  390144  390150  390154  390156  390160  390162  390166  390168  390170  390171  390172  390174  390175  390176  390178  390180  390184  390186  390190  390192  390196  390202  390204  390210  390214  390216  390220  390226  390232  390234  390240  390244  390246  390252  390256  390262  390270  447090 

4.进位制

(1)概念

进位制是一种记数方式,用有限的数字在不同的位置表示不同的数值。可使用数字符号的个数称为基数,基数为n,即可称n进位制,简称n进制。现在最常用的是十进制,通常使用10个阿拉伯数字0-9进行记数。

对于任何一个数,我们可以用不同的进位制来表示。比如:十进数57,可以用二进制表示为111001,也可以用八进制表示为71、用十六进制表示为39,它们所代表的数值都是一样的。

一般地,若k是一个大于一的整数,那么以k为基数的k进制可以表示为:

而表示各种进位制数一般在数字右下脚加注来表示,如111001(2)表示二进制数,34(5)表示5进制数。

(2)进位制间的转换

关于进位制的转换,教科书上以十进制和二进制之间的转换为例讲解,并推广到十进制和其它进制之间的转换。这样做的原因是,计算机是以二进制的形式进行存储和计算数据的,而一般我们传输给计算机的数据是十进制数据,因此计算机必须先将十进制数转换为二进制数,再处理,显然运算后首次得到的结果为二进制数,同时计算机又把运算结果由二进制数转换成十进制数输出。

非十进制数转换为十进制数比较简单,只要计算下面的式子值即可:

第一步:从左到右依次取出k进制数各位上的数字,乘以相应的k的幂,k的幂从n开始取值,每次递减1,递减到0,即

第二步:把所得到的乘积加起来,所得的结果就是相应的十进制数。

十进制数转换成非十进制数

把十进制数转换为二进制数,教科书上提供了“除2取余法”,我们可以类比得到十进制数转换成k进制数的算法“除k取余法”。

非十进制之间的转换

一个自然的想法是利用十进制作为桥梁。教科书上提供了一个二进制数据与16进制数据之间的互化的方法,也就是先有二进制数转化为十进制数,再由十进制数转化成为16进制数。

试题详情

7.将新数据列中的第7个数97与右边相邻的数49进行比较,因为49<97,97应下沉,所以顺序改变,得到新的数据列:

{38,49,65, 76, 13,97, 49,27}

我们把上述过程称为一趟排序。其基本特征是最大的数据沉到底,即排在最左边位置上的数据是数组中最大的数据。反复执行上面的步骤,就能完成排序工作,排序过程不会超过7趟。这种排序的方法称为冒泡排序。

上面的分析具有一般性,如果数据列有n个数据组成,至多经过n-1趟排序,就能完成整个排序过程.

试题详情

6.将新数据列中的第6个数97与右边相邻的数27进行比较,因为27<97,97应下沉,所以顺序改变,得到新的数据列:

{38,49,65, 76, 13,97,27,49}

试题详情

5.将新数据列中的第5个数97与右边相邻的数13进行比较,因为13<97,97应下沉,所以顺序改变,得到新的数据列:

{38,49,65, 76, 13,97,27,49}

试题详情

4.将新数据列中的第4个数97与右边相邻的数76进行比较,因为76<97,97应下沉,所以顺序不变,得到新的数据列:

{38,49,65, 76,97,13,27,49}

试题详情

3.将新数据列中的第3个数65与右边相邻的数97进行比较,因为97>65,所以顺序不变,得到新的数据列:

{38,49,65,97,76,13,27,49}

试题详情

2.将新数据列中的第2个数49与右边相邻的数65进行比较,因为65>49,所以顺序不变,得到新的数据列:

{38,49,65,97,76,13,27,49}

试题详情

1.将第1个数与右边相邻的数38进行比较,因为38<49,49应下沉,即向右移动,所以交换他们的位置,得到新的数据列:

{38,49,65,97,76,13,27,49}

试题详情

3.排序

排序的算法很多,课本主要介绍里两种排序方法:直接插入排序和冒泡排序

(1)直接插入排序

在日常生活中,经常碰到这样一类排序问题:把新的数据插入到已经排好顺序的数据列中。

例如:一组从小到大排好顺序的数据列{1,3,5,7,9,11,13},通常称之为有序列,我们用序号1,2,3,……表示数据的位置,欲把一个新的数据8插入到上述序列中。

完成这个工作要考虑两个问题:

(1)确定数据“8”在原有序列中应该占有的位置序号。数据“8”所处的位置应满足小于或等于原有序列右边所有的数据,大于其左边位置上所有的数据。

(2)将这个位置空出来,将数据“8”插进去。

对于一列无序的数据列,例如:{49,38,65,97,76,13,27,49},如何使用这种方法进行排序呢?基本思想很简单,即反复使用上述方法排序,由序列的长度不断增加,一直到完成整个无序列就有序了.

首先,{49}是有序列,我们将38插入到有序列{49}中,得到两个数据的有序列:

{38,49},

然后,将第三个数据65插入到上述序列中,得到有序列:

{38,49,65}

…………

按照这种方法,直到将最后一个数据65插入到上述有序列中,得到

{13,27,38,49,49,65,76,97}

这样,就完成了整个数据列的排序工作。注意到无序列“插入排序算法”成为了解决这类问题的平台.

(2)冒泡法排序

所谓冒泡法排序,形象地说,就是将一组数据按照从小到大的顺序排列时,小的数据视为质量轻的,大的数据视为质量沉的。一个小的数据就好比水中的气泡,往上移动,一个较大的数据就好比石头,往下移动。显然最终会沉到水底,最轻的会浮到顶,反复进行,直到数据列排成为有序列。以上过程反映了这种排序方法的基本思路。

我们先对一组数据进行分析。

设待排序的数据为:{49,38,65,97,76,13,27,49}

排序的具体操作步骤如下:

试题详情

2.秦九韶算法

秦九韶算法的一般规则:

秦九韶算法适用一般的多项式f(x)=anxn+an-1xn-1+….+a1x+a0的求值问题。用秦九韶算法求一般多项式f(x)= anxn+an-1xn-1+….+a1x+a0当x=x0时的函数值,可把n次多项式的求值问题转化成求n个一次多项式的值的问题,即求

v0=an

v1=anx+an-1

v2=v1x+an-2

v3=v2x+an-3

……..

vn=vn-1x+a0

观察秦九韶算法的数学模型,计算vk时要用到vk-1的值,若令v0=an

我们可以得到下面的递推公式:

v0=an

vk=vk-1+an-k(k=1,2,…n)

这是一个在秦九韶算法中反复执行的步骤,可以用循环结构来实现.

试题详情


同步练习册答案