Ch3 数据类型
CH3习题参考答案
习题3解答判断题1.栈和队列都是限制存取点的线性结构(TRUE)2.栈和队列是两种重要的线性结构。
( TRUE )3.带头结点的单链表形式的队列,头指针F指向队列的头结点,尾指针R指向队列的最后一个结点(TRUE)4.在对不带头结点的链队列作出队操作时,不会改变头指针的值。
(FALSE)单项选择题:5.若已知一个栈的入栈序列是1,2,3,…,n,其输出序列为p1,p2,p3,…,p n,若p1=n,则p i为( )。
A.i B.n=i C.n-i+1 D.不确定答:C[当p1=n,即n是最先出栈的,根据栈的原理,n必定是最后入栈的,那么输入顺序必定是1,2,3,…,n,则出栈的序列是n,…,3,2,1,所以答案是C。
] 6.栈和队列的共同点是( )。
A.都是先进后出B.都是先进先出C.只允许在端点处插入和删除元素D.没有共同点答:C7.若依次输入数据元素序列{a,b,c,d,e,f,g}进栈,出栈操作可以和入栈操作间隔进行,则下列哪个元素序列可以由出栈序列得到?( )A.{d,e,c,f,b,g,a} B.{ f,e,g,d,a,c,b}C.{e,f,d,g,b,c,a} D.{ c,d,b,e,g,a,f}答:A8.一个栈的入栈序列是1,2,3,4,5,则下列序列中不可能的出栈序列是( )A. 2,3,4,1,5B. 5,4,1,3,2C. 2,3,1,4,5D. 1,5,4,3,2答:B9. 队列操作的原则是( )A. 先进先出B. 后进先出C. 只能进行插入D. 只能进行删除答:A10. 栈的插入与删除是在( )进行。
A.栈顶B. 栈底C. 任意位置D. 指定位置答:A11.假设顺序栈的定义为:typedef struct {selemtype *base; /* 栈底指针*/selemtype *top; /* 栈顶指针*/int stacksize; /* 当前已分配的存储空间,以元素为单位*/ }sqstack;变量st为sqstack型,则栈st为空的判断条件为()。
关系数据库语言SQL(ch3-2)
left [outer] join 左外连接
左边表和右边表满足连接条件的记录取出为结果集,加上 左边表和右边表满足连接条件的记录取出为结果集, 左边表未匹配的记录
right [outer] join 右外连接
左边表和右边表满足连接条件的记录取出为结果集, 左边表和右边表满足连接条件的记录取出为结果集,加上 右边表未匹配的记录
SELECT Sno,Sname,Sdept , , FROM Student WHERE Sdept IN (SELECT Sdept FROM Student WHERE Sname= ‘ 刘晨 ’); ;
(8)带有ANY谓词的子查询 )带有 谓词的子查询
[例] 查询其他系中比信息系任意一个(其中某一个) 例 查询其他系中比信息系任意一 其中某一 学生年龄小的学生姓名和年龄. 学生年龄小的学生姓名和年龄 SELECT Sname,Sage , FROM Student WHERE Sage < ANY (SELECT Sage FROM Student WHERE Sdept= ' IS ') AND Sdept <> ' IS ' ; /* 注意这是父查询块中的条件 */
(3)自身连接 )
[例] 查询每一门课的间接先修课 即先修课的先修课 例 查询每一门课的间接先修课,
Course表结构为:Cno,Cname,Cpno,Ccredit 表结构为: 表结构为
SELECT o,SECOND.Cpno , FROM Course FIRST,Course SECOND , WHERE FIRST.Cpno = o; ;
(11) 带有 带有EXISTS谓词的子查询 谓词的子查询
VFP基础培训教程教案
5.3 关系 P80
建立关系的前提:①有公共字段;②有公共索引。 建立关系:①在建立关联的数据库中建立好索引, 且必须有一个主索引;②在数据库设计器中,用鼠 标从一数据库的主索引拖到另一数据库的某个索引 项上。
–
一、用查询向导创建查询P87 用查询向导创建查询
1.启动查询向导 2.字段选取 3.为表建立关系 4.包含记录 5.筛选记录 6.排序记录 7.限制记录 8.完成
用查询设计器创建查询P92 二、 用查询设计器创建查询
一、发展历程
①80年代:Ashton公司的dBASE。②86年:Fox公司的 FoxBase+。③94年:微软公司推出面向中国市场的 FoxPro 。④95年:VFP3.0 VFP6.0。
二、特点
①检索速度最快:Rushmore SQL ②有丰富的开发工具 ③支持面向对象的可视化编程技术 ④可生成真正的事件驱动的应用程序 ⑤支持客户/服务器结构
在项目管理器中,①选择要修改的表—修改,打开 表设计器;②字段;③修改—改错、排列顺序、插 入字段、删除字段;④确定。
4.5 浏览 P61
4.6 维护表记录 P54
编辑字段内容 输入G、M型字段内容:双击
–
G:A.编辑—插入对象。B.粘贴
增加记录:A.显示—追加方式。B.表—追加新记录; 删除记录:表—删除记录、彻底删除、恢复记录、 切换删除标志 定位记录:表—转到记录 替换记录:表—替换字段
数据与程序的关系图
应用程序1 数 据 库 DATABASE
ch3交通运输需求与供给
需求曲线右移
•需求曲线右移
•如图所示,需求曲线的右移会引起什么样的变化?
24
•,
原需求曲线为D,新需求曲线D1在D的右边,即需求曲线发生 了右移。在同样的价格水平p下,在原需求曲线D上对应的A点
的需求量为Q,在新需求曲线D1上对应的B点的需求量为Q1 ,
这里:
Q1 Q
这就意味着在新的需求曲线下,同样价格水平下需求数量增加了。
25
•需求曲线左移
•图2-2-4 需求曲线左移
•如图所示,需求曲线的左移又会引起什么样的变化?
26
原需求曲线为D,新需求曲线D2在D的左边,即需求曲线发生 了左移。在同样的价格水平p下,在原需求曲线D上对应的A点
的需求量为Q,在新需求曲线D2上对应的C点的需求量为Q2 ,
这里:
Q2 Q
这就意味着在新的需求曲线下,同样价格水平下需求数量减少了。
旅客运输需求中生产性旅行需求的价格弹性较小,尤其是客运中 的出差、探亲等公费旅行弹性小;消费性出行需求的价格弹性较
大,但其还受收入水平高低的影响。 货物运输需求的价格弹性与货物价值有关,价值小的弹性大,反 之弹性小。价格弹性的大小还同货物的季节性以及市场有关。
(1)运输需求价格弹性的计算方法 A.点弹性:是运输需求曲线上某一点的弹性
Ed
Q变动率 Z变动率
Q / Q Z / Z
含义:影响因素每变化一个量,运输需求量相应变化的量。
运输需求的影响因素很多,重点讨论:价格弹性、收入弹性、交 叉弹性和派生弹性。
(一)运输需求的价格弹性
运输需求的价格弹性EP 反应了运输对运输价格变动的 反应程度(或灵敏度)。
Ep Q / Q P / P
c语言基本数据类型哪三种
c语言基本数据类型哪三种
C语言的基本数据类型分为整型、实型(浮点型)和字符型三种。
1.整型(Integer Types):包括短整型(short)、整型(int)、长整型(long)等,用于表示一个整数。
整型默认为有符号型,但也可以配合unsigned关键字表示为无符号型。
2.实型(Floating-point Types),即浮点型:包括单精度浮点型(float)和双精度浮点型(double)等,用于表示实数,即带有小数部分的数值。
需要注意的是,实型在计算机语言中为近似值表示,并非准确值,因此在多次计算后可能会出现真值偏差。
3.字符型(Character Types):即char型,用于表示各种字符,与ASCII码表一一对应。
除了可以用来表示各类字符外,char型的其它规则与整型相同,因此可以认为char是一种特殊的整型。
这些类型按其在计算机中的存储方式可被分为两个系列,即整数(integer)类型和浮点数(floating-point)类型。
而每种类型又都包含了不同的关键字和符号说明符,如signed和unsigned,用于表示该类型是有符号还是无符号。
字符串类型
北京源智天下科技有限公司
1-7
联系方式:
SET列的集合成员不是按顺序编号的,而是每个成员对应SET值中 的一个二进制位。第一个集合成员对应于0位,第二个成员对应于1位, 依此类推。数值SET值0对应于空串。SET成员以位值保存。每个字节 的8个集合值可按此方式存放,因此SET列的存储值大小是由集合成员 的数目决定的,最多是64个成员。 SET定义中的值顺序决定了在显示由多个集合成员组成的SET列值 时,子串出现的顺序。例如一个列被设定为SET color("red","black","green","yellow"),其存放位置顺序如表17-5所示。
北京源智天下科技有限公司
1-9
联系方式:
表17-3 CHAR类型和VARCHAR类型的对比
CHAR(4) ' ' ‘ab ' ‘abab' ‘abca' 存储需求 4字节 4字节 4字节 4字节 值 '' ‘ab' ‘abab' ‘abcabcab' VARCHAR(4) '' ‘ab' ‘abab' ‘abca' 存储需求 1字节 3字节 5字节 R和VARCHAR数据类型 和 数据类型 BLOB和TEXT类型 和 类型 ENUM类型 类型 SET类型 类型
北京源智天下科技有限公司
1-1
联系方式:
CHAR和VARCHAR数据类型 和 数据类型
CHAR数据类型用于表示固定长度的字符串,长度可以是1~255之间 的任何值。VARCHAR的列中的值是变长字符串,取值范围同CHAR类型 相同。 CHAR和VARCHAR数据类型的区别主要在于存储时所需空间不同。当 一个给定列为char类型时,存储时其长度将被修正为创建表时所声明的长 度。而VARCHAR值只存储所需的字符,外加一个字节记录长度,值不被 填补。如表17-3所示为存储一系列不同的串值到CHAR(4)和VARCHAR (4)列的结果。
C-ch3
小数形式:12121.121; 指数形式:12121.1321 e 3 或 12121.1321 E 3 或1.21211321e7;
12121.1321 103
©2013-9-10
18
§ 3. 4 实型数据
[上一张] [下一张]
3.4.2 实型变量
实型变量:用于存储实数的变量(在计算 机中通常按指数形式存放);
7ቤተ መጻሕፍቲ ባይዱ
3.3 整型数据 (Integer)
整型常量的表示方法 整型变量
整型数据在内存中的存放形式 整型变量的类型 整型变量的定义 整型数据的溢出
整型常量的类型
©2013-9-10
8
§ 3.3 整型数据(Integer)
3.3.1 整型常量
10进制数 123 -23423 0 8进制数(以0开头) 011(十进制9) 16进制数(以0x开头) 0xf(十进制15)
#include <stdio.h> main( ) { int num,total; num=10; total=num*PRICE; printf(―total=%d‖,total); }
total = num * 30; =>
相当于把标识符用一个常量简单替换下来
©2013-9-10
4
§ 3.2 常量与变量
char c1=‗a‘; 65 66……………………. 90 c1=c1-32; printf(―%c %d‖,c1,c1);
}
运行结果
A 65
©2013-9-10
27
3.5.4 字符串常量
C语言数据类型及表示范围
C语言各种数据类型在系统中占的字节和取值范围基本类型包括字节型(char)、整型(int)和浮点型(float/double)。
定义基本类型变量时,可以使用符号属性signed、unsigned(对于char、int),和长度属性short、long(对于int、double)对变量的取值区间和精度进行说明。
下面列举了Dev-C++下基本类型所占位数和取值范围:符号属性长度属性基本型所占位数取值范围输入符举例输出符举例-- -- char 8 -2^7 ~ 2^7-1 %c %c、%d、%u signed -- char 8 -2^7 ~ 2^7-1 %c %c、%d、%u unsigned -- char 8 0 ~ 2^8-1 %c %c、%d、%u [signed] short [int] 16 -2^15 ~ 2^15-1 %hdunsigned short [int] 16 0 ~ 2^16-1 %hu、%ho、%hx [signed] -- int 32 -2^31 ~ 2^31-1 %dunsigned -- [int] 32 0 ~ 2^32-1 %u、%o、%x[signed] long [int] 32 -2^31 ~ 2^31-1 %ldunsigned long [int] 32 0 ~ 2^32-1 %lu、%lo、%lx [signed] long long [int] 64 -2^63 ~ 2^63-1 %I64dunsigned long long [int] 64 0 ~ 2^64-1 %I64u、%I64o、%I64x -- -- float 32 +/- 3.40282e+038 %f、%e、%g-- -- double 64 +/- 1.79769e+308 %lf、%le、%lg %f、%e、%g -- long double 96 +/- 1.79769e+308 %Lf、%Le、%Lg几点说明:1. 注意! 表中的每一行,代表一种基本类型。
ch31jsp
♥ C++允许使用转义字符来表示不可见字符;
♥ 可见字符的转义字符的形式表示法;
‘\101’
‘\x41’
♥ 反斜杠的表示方法:用’\\’ 表示。
路径表示方法:”c:\\c实验\\ex1”
3.2 枚举型
为什么需要枚举类型 ?
♥ 问题的提出:有一行代码,它表达今天是周3:
int today = 3;
11111111(全1)代表 -1
♥ 参考P67表3-2
♥ 可加在int前的数据类型修饰符:long,short ♥ 所占字节数应有:short int ≤ int ≤ long int ♥ 可用基本操作符sizeof 来测试类型长度 cout<<“Size of long int is: ”<< sizeof(long) ;
定义枚举类型的基本语法
enum 枚举类型名 {枚举值1,枚举值2,…… };
enum : 是定义枚举类型的关键字。
枚举类型名 :我们要自定义的新的数据类型的名字。
枚举值 :可能的个值。
如:
enum Week{ Mon, Tue, Wed, Thu, Fri, Sat, Sun };
需要注意的问题
♥ 如何确定花括号中的名称代表的整数值
默认时,第一个名字对应整数0,第二个对应1,依
此类推;
也可以人为规定;
♥ 枚举值,我们就称为枚举常量,因为它一经定
int b=a; int c=‘a’; ♥ 区别:输出形式与整型数不同: cout<<a<<endl; cout<<b<<‘\n’; cout<<b<<‘\t’<<c<<‘\n’;
C语言数据类型及表示范围
C语言各种数据类型在系统中占的字节和取值范围基本类型包括字节型(char)、整型(int)和浮点型(float/double)。
定义基本类型变量时,可以使用符号属性signed、unsigned(对于char、int),和长度属性short、long(对于int、double)对变量的取值区间和精度进行说明。
下面列举了Dev-C++下基本类型所占位数和取值范围:符号属性长度属性基本型所占位数取值范围输入符举例输出符举例-- -- char 8 -2^7 ~ 2^7-1 %c %c、%d、%u signed -- char 8 -2^7 ~ 2^7-1 %c %c、%d、%u unsigned -- char 8 0 ~ 2^8-1 %c %c、%d、%u [signed] short [int] 16 -2^15 ~ 2^15-1 %hdunsigned short [int] 16 0 ~ 2^16-1 %hu、%ho、%hx [signed] -- int 32 -2^31 ~ 2^31-1 %dunsigned -- [int] 32 0 ~ 2^32-1 %u、%o、%x[signed] long [int] 32 -2^31 ~ 2^31-1 %ldunsigned long [int] 32 0 ~ 2^32-1 %lu、%lo、%lx [signed] long long [int] 64 -2^63 ~ 2^63-1 %I64dunsigned long long [int] 64 0 ~ 2^64-1 %I64u、%I64o、%I64x -- -- float 32 +/- 3.40282e+038 %f、%e、%g-- -- double 64 +/- 1.79769e+308 %lf、%le、%lg %f、%e、%g -- long double 96 +/- 1.79769e+308 %Lf、%Le、%Lg几点说明:1. 注意! 表中的每一行,代表一种基本类型。
汇编语言程序设计(第二版)课后题答案
4.1、判断下列标识符的合法性。
1)、code 合法2)、Data 合法3)、ABCDH 合法4)、1abcH 不5)、eax 不6)、01 合法7)、A?@ 合法8)、www@zsu 合法9)、***********.cn不10)、AX$DX 合法11)、_BX 合法12)、CX 不4.2、按下面要求写出相应的数据定义语句(未指定变量名的,可任意指定或省缺)。
1)、定义一个字节区域,第一个字节的值为20,其后跟20个初值为0的连续字节;DB 20,20 DUP(0)2)、定义一个以0为结束符的字符串,其初值为:The course is easy;DB “The course is easy”,03)、定义一个以'$'为结束符的字符串,该串中含有换行符和回车符;DB 0D,0A,”$”4)、定义100个字,其初值为0;DW 100 DUP(0)5)、从一个偶地址开始定义一个字变量word;EVENWORD DW ?6)、先定义一个字符串String,其偏移量指定为10,其初值为"ABCDEF",然后再定义3个字类型的数组Data,要求String和Data的偏移量相同;ORG 10STRING DB "ABCDEF"ORG 10DATA DW 3 DUP(?)7)、定义一个字符串String,其初值为"12345678",再定义4个字类型的数组Data,要求String和Data共享同一片内存单元;STRING DB "12345678"ORG $-8DATA DW 4 DUP (?)4.3、把下列C语言的变量定义语句改写成与之等价的汇编语言语句。
1)、char ch1, ch2[3], ch3[]="Are you ready?", ch4='Q';CH1 DB ?CH2 DB 3 DUP (?)CH3 DB "Are you ready?",0CH4 DB “Q”2)、int w1, w2[5], w3=0x1234, w4[]={90, 89, 432, 344};W1 DW ?W2 DW 5 DUP (?)W3 DW 1234HW4 DW 90,89,432,3443)、long int d1=1234, d2, d3[10], d4[]={1, 2, 3, 4, 5, 6};D1 DD 1234D2 DD ?D3 DD 10 DUP(?)D3 DD 1,2,3,4,5,64.4、假设4.3题中三组变量在内存中是连续存放的,且变量ch1的偏移量是20H,试求出其它每个变量的偏移量。
c教案ch3数据类型与运算符.
变量名
a
3
变量的值
变量的存储单元 变量定义语句的功能: 变量定义语句指挥系统为变量分配存储空间, 变量的类型决定了分配存储空间的大小.
实验程序: #include <stdio.h> void main() { printf("各类变量所占字节数为:\n"); printf("整型 int: %d\n",sizeof(int)); printf("短整型 short: %d\n",sizeof(short)); printf("单精度实型 float: %d\n",sizeof(float)); printf("双精度实型 double: %d\n",sizeof(double)); }
-215—215-1
-231—231-1 (P43(10位数)) 0—216-1 (0~65535) 0—216-1 0—232-1 (P43(10位数))
long [int] unsigned [int] unsigned short [int] unsigned long [int]
整型变量:常用的是 int 和 long
一般形式: #define 标识符 常量
total=num*PRICE; //2)计算总价: total
printf("total=%d\n",total); //3) 输出总价 }
如, #define PI 3.1415926
优点:含义清楚,灵活机动,易于修改。 注意:符号常量通常用大写字母表示。
§3.3 整型数据
一 整型常量 (三种形式)
① 十进制常数 如, 123、-12、0 ② 八进制常数 由数字0~7组成,最高位必须用0 做引导符!!! 如, 012 --- (12)8 =(10)10 、-012 ③ 十六进制常数 由0~9和a~f(A~F)组成,最高位必须用0x(0X) 做引导符。 如, 0x12 --- (12)16 =(18)10 0xaf --- (af)16 =10*16+15=(175)10 实验程序: #include <stdio.h> void main() { int n=012,m=0x12; printf("n=(%o)8,(%d)10,(%x)16\n",n,n,n); printf("m=(%x)16, (%d)10,(%o)8\n",m,m,m);
ch3
东北师范大学计算机学院
2010年秋季学期 2010年秋季学期
Professional Words
Data type Constant Variable Expression Declaration Initialization assignment Identifier Reserved words
9
东北师范大学计算机学院
2010年秋季学期 2010年秋季学期
2、变量(Variable) 、变量
程序运行中其值可以改变的量称为变量。与一个 程序运行中其值可以改变的量称为变量。 变量相关的内容:变量名(name) (name), 变量相关的内容:变量名(name), 变量的值 (Value),变量所占的存贮单元( (Value),变量所占的存贮单元(地址 Address) Address)。给变量的起名要符合标识符 (Identifier)的定义 的定义。 语言规定标识符中可以 (Identifier)的定义。C语言规定标识符中可以 由字母(letter)、数字(digit)和下划线 由字母(letter)、数字(digit) underscore)组成, (underscore)组成,且第一个字符必须是字母或 下划线。 下划线。 例如, 例如,a2,_abc,_ABC,a_1,123,8a
12
东北师范大学计算机学院
2010年秋季学期 2010年秋季学期
三、整型数据(integer) 整型数据
1. 整型数据在内存中的存放 . 用二进制进行存贮, 用二进制进行存贮,且用补码表示 复习进制、原码,反码, 复习进制、原码,反码,补码方面的知识 2. 整型常量的表示方法 . 十进制数(Decimal):直接写 十进制数 : 八进制数(Octal):以数字 开头 八进制数 :以数字0开头 022、-037 、 010和10大小不一样 和 大小不一样 十六进制数(Hexadecimal):以0x开头 十六进制数 : 开头 0x12、-0x1F, -0x1f 、
ch3_数组
第 3 章数组运算及数组化编程与其它编程语言不同,MATLAB数据的保存和传送的基本单元不是标量,而是复数阵列型数据,即数组;MATLAB算术、关系、逻辑运算的基本运算单元也不是标量,而是数组;MATLAB提供的许多M函数的基本作用单元也不是标量,而是数组。
基于数组、数组运算在MATLAB中的基本地位,本章将系统阐述:有关数组的各种基本概念、数组的编制和寻访、数组运算的基本含义和通则、以及数组化编程的重要性。
对于外形、元素排列和编址都与二维数组相同,但概念、运算规则又绝然不同的矩阵,本章也将安排专门的节次加以详述。
不但讲述矩阵与数组的区别,而且要特别强调矩阵化编程的重要性,因为矩阵是MATLAB诞生和发展的原动力。
本章之所以如此强调数组与矩阵的区别,是为了帮助读者正确理解“MATLAB帮助文档中Matrix、Vector英文词汇的泛义以及在它们不同意境下定义的两组运算”。
3.1数组、结构和创建3.1.1数组及其结构1数组的维度图 3.1-1 二维数组的结构及相关术语2数组的规模及相关术语3获取数组结构参数的M指令〖说明〗3.1.2行(列)数组的创建1递增/减型行(列)数组的创建〖说明〗2其他类型行(列)数组的创建(1)(2)【例3.1-1】a1=1:6 %na1=ndims(a1) %Sa1=size(a1) %La1=length(a1) %a1 =1 2 3 4 5 6na1 =1 6La1 =6a2=0:pi/4:pi %a3=1:-0.1:0 %a2 =0 0.7854 1.5708 2.3562 3.1416a3 =Columns 1 through 61.0000 0.9000 0.8000 0.7000 0.6000 0.5000 Columns 7 through 110.4000 0.3000 0.2000 0.1000 0b1=linspace(0,pi,4) %b2=logspace(0,3,4) %b1 =0 1.0472 2.0944 3.1416b2 =1 10 100 1000c1=[2 pi/2 sqrt(3) 3+5i] %c1 =Columns 1 through 32.0000 1.5708 1.7321Column 43.0000 + 5.0000irng default %c2=rand(1,5) %c2 =0.8147 0.9058 0.1270 0.9134 0.6324〖说明〗3.1.3二维通用数组的创建1小规模数组的直接输入法【例3.1-2】1)a=2.7358; b=33/79; %na=ndims(a) %sa=size(a) %na =2sa =1 12)C=[1,2*a+i*b,b*sqrt(a);sin(pi/4),a+5*b,3.5+i] %nC=ndims(C) %SC=size(C) %C =1.0000 + 0.0000i 5.4716 + 0.4177i 0.6909 + 0.0000i0.7071 + 0.0000i 4.8244 + 0.0000i 3.5000 + 1.0000iSC =2 3〖说明〗2中规模数组的数组编辑器创建法【例3.1-3】0.6459 0.9637 0.5289 0.0710 0.8326 0.97860.4376 0.3834 0.5680 0.0871 0.7782 0.79920.89180.7917 0.9256 0.0202 0.8700 0.4615操作步骤如下:1)2)3)4)图3.1-23中规模的M文件创建法【例3.1-4】操作步骤如下:1)打开文件编辑器EDITOR2)编写脚本内容3)保存文件4)运行文件生成数组图3.1-3 4利用MATLAB函数创建数组【例3.1-5】ones(2,4) %ans =1 1 1 11 1 1 1rng(0) %randn(2,3) %ans =0.5377 -2.2588 0.31881.8339 0.8622 -1.3077D=eye(3) %D =1 0 00 1 00 0 1diag(D) %ans =111diag(diag(D)) %ans =1 0 00 1 00 0 1randsrc(3,20,[-3,-1,1,3],1)%%ans =Columns 1 through 12-1 -1 -3 1 -3 1 -3 3 3 -3 -3 1 1 -3 -1 -1 3 -1 -3 -1 3 -3 -1 1 -3 -3 -1 1 -3 1 3 1 -3 3 3 -1 Columns 13 through 201 3 -1 -1 -1 1 -1 -33 3 3 3 -3 -3 -3 1-3 1 -3 -1 -3 -1 1 13.1.4数组构作技法综合【例 3.1-6】a=1:8 %A=reshape(a,4,2) %A=reshape(A,2,4) %a =1 2 3 4 5 6 7 8A =1 52 63 74 8A =1 3 5 72 4 6 8b=diag(A) %B=diag(b) %b =14B =1 00 4D1=repmat(B,2,4) %D1 =1 0 1 0 1 0 1 00 4 0 4 0 4 0 41 0 1 0 1 0 1 0 0 4 0 4 0 4 0 4 D1([1,3],: )=[ ] %D1 =0 4 0 4 0 4 0 4 0 4 0 4 0 4 0 4 【例3.1-7】A=reshape(1:9,3,3)A =1 4 72 5 83 6 9B=flipud(A) %B =3 6 92 5 81 4 7C=fliplr(A) %C =7 4 18 5 29 6 3D=rot90(A,2) %D =9 6 38 5 27 4 13.2数组元素编址及寻访3.2.1数组元素的编址1全下标编址和单序号编址(1)(2)图 3.2-12两种编址间的转换〖说明〗3.2.2二维数组元素的寻访1按址寻访2按条件寻访【例3.2-1】1)clearA=[1:3:16;2:3:17;3:3:18] %A =1 4 7 10 13 162 5 8 11 14 173 6 9 12 15 18 2)Ass1=A(2,3) %r=[2,3]; %c=[1,5]; %As22=A(r,c) %%Ass1 =8As22 =2 143 15As26=A([1,3],:) %As26 =1 4 7 10 13 16 3 6 9 12 15 18 3)Ais1=A(8) %ind=[1,3,18]; %%Ai1r=A(ind) %Ai1c=A(ind') %Ais1 =8Ai1r =1 3 18Ai1c =13184)A(r,c)=zeros(2,2) %A([1,end])=-A([1,end]) %<13>A =1 4 7 10 13 16 0 5 8 11 0 170 6 9 12 0 18A =-1 4 7 10 13 16 0 5 8 11 0 17 0 6 9 12 0 -18 5)L=A<=0 %AL=A(L) %L =1 0 0 0 0 0 1 0 0 0 1 0 1 0 0 0 1 1 AL =-1-18A(L)=NaN %A =NaN 4 7 10 13 16 NaN 5 8 11 NaN 17 NaN 6 9 12 NaN NaN 〖说明〗3.3数组运算3.3.1实施数组运算的算符1算符数组运算通则2算术、关系、逻辑算符3 各种算符的优先级别4 算符数组运算实例及机理解释【例3.3-1】cleart=-3*pi:pi/10:3*pi; % st=sin(t); %<3> y=st./t; %<4> Lt=(t==0); %<5> tt=t+Lt.*realmin;%<6> yy=sin(tt)./tt; %<7>subplot(1,2,1),plot(t,y),axis([-9,9,-0.5,1.2]), xlabel('t'),ylabel('y'),title('残缺图形')subplot(1,2,2),plot(tt,yy),axis([-9,9,-0.5,1.2])〖说明〗图 3.3-2图 3.3-3图 3.3-4【例3.3-2】 1)A=[-2,-1,0,0,1,2,3] B=[0,-1,1,0,1,-2,-3]disp(['A 的数据类型是', class(A)])A =-2 -1 0 0 1 2 3B =0 -1 1 0 1 -2 -3A的数据类型是double2)R1=A==B %<4>R2=A>B %<5>fprintf('R1的数据类型是什么? %s\n',class(R1))fprintf('R2的数据属于逻辑类?(1为真;0为假) %d\n',islogical(R2)) %<7> R1 =0 1 0 1 1 0 0R2 =0 0 0 0 0 1 1R1的数据类型是什么? logicalR2的数据属于逻辑类?(1为真;0为假) 13)LA=logical(A) %<8>LB=logical(B)L1=LA&LBLL1=A&B %LA =1 1 0 0 1 1 1LB =0 1 1 0 1 1 1L1 =0 1 0 0 1 1 1LL1 =0 1 0 0 1 1 14)L3=xor(LA,LB) %LL3=xor(A,B) % <12>L3 =1 0 1 0 0 0 0LL3 =1 0 1 0 0 0 05)TOTAL1=all([1,1,1,1,1])TOTAL2=all([1,0,1,1,1])TOTAL1 =1TOTAL2 =6)ANYONE1=any([0,1,0,0,0])ANYONE2=any([0,0,0,0,0])ANYONE1 =1ANYONE2 =〖说明〗3.3.2 实施数组运算的函数 1 函数数组运算通则2 服从数组运算通则的M 函数3.3.3 数组运算中的溢出及非数处理3.3.4 数组化编程(1) (2)【例3.3-3】311()cos(2)111x x x y x x x x e xπ-+≤-⎧⎪=-<≤⎨⎪<⎩1)function y=exm030303_1(x) % exm030303_1 % x % y M=length(x); y=zeros(1,M);for jj=1:Mif x(jj)<=-1y(jj)=x(jj);elseif -1<x(jj)&&x(jj)<=1y(jj)=x(jj)^3*cos(2*pi*x(jj));elsey(jj)=exp(-x(jj)+1);endendfunction y=exm030303_2(x)% exm030303_2L1=x<=1; %<2>L2=-1<x&x<=1; %<3>L3=1<x; %<4>y=zeros(size(x));%<5>y(L1)=x(L1); %<6>y(L2)=x(L2).^3.*cos(2*pi*x(L2)); %<7>y(L3)=exp(-x(L3)+1); %<8>2)x=-2:0.01:2; %y1=exm030303_1(x); %y2=exm030303_2(x); %e12=max(abs(y1(:)-y2(:))) %clf %plot(x,y2,'r','Linewidth',3) %xlabel('x'),ylabel('y') %grid on %axis([-2,2,min(min(y1)),max(max(y1))]) % e12 =〖说明〗3.4矩阵及其运算3.4.1矩阵和数组的异同3.4.2矩阵运算符和矩阵函数 1独特的矩阵运算符2矩阵函数【例 3.4-1】1)Am=magic(3) %Aa=reshape(1:12,3,4) %B=repmat(1:4,3,1) %Am =8 1 63 5 74 9 2Aa =1 4 7 102 5 8 113 6 9 12B =1 2 3 41 2 3 41 2 3 42)AmmB=Am*B %AamB=Aa.*B %AmmB =15 30 45 6015 30 45 6015 30 45 60AamB =1 8 21 402 10 24 443 12 27 483)AmLdB=Am\B %AaadB=Aa.\B %AmLdB =0.0667 0.1333 0.2000 0.2667 0.0667 0.1333 0.2000 0.2667 0.0667 0.1333 0.2000 0.2667 AaadB =1.0000 0.5000 0.4286 0.4000 0.5000 0.4000 0.3750 0.3636 0.3333 0.3333 0.3333 0.3333 4)Amm2=Am^2 %Ama2=Am.^2 %Amm2 =91 67 6767 91 6767 67 91Ama2 =64 1 369 25 4916 81 45)Am2m=2^Am % Am2a=2.^Am % Am2m =1.0e+04 *1.0942 1.0906 1.0921 1.0912 1.0933 1.0924 1.0915 1.0930 1.0923 Am2a =256 2 64 8 32 128 16 512 46)rng(0) % D=randn(3,3); % AmLdD=Am\D % DRdAm=D/Am % AmLdD =-0.3301 -0.0027 0.1153 -0.2305 -0.1836 0.4118 0.5681 0.1778 -0.2946 DRdAm =0.0349 -0.1404 0.1699 0.2438 -0.1931 0.1156 -0.3222 0.9731 -0.65013.4.3 矩阵化编程【例 3.4-2】采用“实数标量+循环”法和“MATLAB 矩阵乘算符”分别计算两个复数矩阵m p ⨯A 和p n ⨯B 的乘积。
raptor程序设计案例教程-ch3
使用数组编排成绩表
从键盘输入3个学生的信息,这些信息包括 :学号、姓名、英语、计算机、数学、总 分、平均分:
其中总分和平均分不需要输入,通过程序自动 计算
最后按总分从高到低依次输入3个学生的相关信 息
成绩表流程图
Main子图
成绩表流程图
Init子图
成绩表流程图
Sort子图
成绩表流程图
Swap子图
成绩表流程图
Display子图
数组应用注意事项
在RAPTOR中,一旦某个变量名被用做数组 变量,就不允许存在一个同名的非数组变 量
RAPTOR数组可以在算法运行过程中动态增 加数组元素;但不可以将一个一维数组在 算法运行中扩展成二维数组
RAPTOR数组的特点
下标要紧跟在数组名后,而且用方括号括 起来(不能用其他括号);
下标可以是常量,变量或表达式,但其值 必须是整数(如果是小数将四舍五入);
下标必须为一段连续的整数,其最小值成 为下界,其最大值成为上界。不加说明时 下界值默认为1。
RAPTOR数组的最大元素个数在10000个左右 ,建议不要超此上限。
计算某个班级学员的一个学期4门课程的平 均成绩。
应该如何保存参与计算的课程成绩 可以分别使用:computer[],math[],
physica[],history[],而每个同学的编号, 可以用做数组的下标
多种数据类型元素共存的数组
RAPTOR并不强 制每个数组的 元素必须具备 相同的数据类 型
数组变量的应用
数组变量的 好处来自数 组符号允许 RAPTOR在方 括号内执行 数学计算
利用数组编写程序,求 1+3+……+99的值
C++ch3
类 类 型
CC++:扩展面向对象
CC++:增加了非面向对象的新特性
CC++:完全兼容C语言 C++中增加面向对象的概念,允许用 户定义新的抽象数据类型—类类型。
类—将一组数据和对它们的相关操作封装 在一起。
3.1 类与对象
3.1.1 类的例子 一、类中的成员: 1、数据—数据成员; 2、操作—成员函数; 私有段成员 类
Empty *p1=&e1;
Void f( ) {
if(p1==&e2)
cout<<“impossible\n”; else
cout<<“that is right\n”;
}
对“类”的总结 (1)、用户自定义类型; (2)、是数据隐藏和封装的单位,将细节封装,只允许通过 公有段数据和函数被访问,从而支持数据抽象的机制; (3)、通过虚函数支持多态性; (4)、类是一种模块单位 模块—只含有静态成员的类
三、析构函数—解决善后工作。 (1)属于某一个类
特殊成员函数 1、函数名与类名相同 (2)可由用户定义—做用户的善后工作 2、可有任意类型参数,但 (3)系统缺省—做公共的善后工作。 不能有返回类型 3、创建一个对象时,系统 四、使用构造函数和析构函数 自动调用它
1、实例: String::string ( )
(2)在系统实现上—类是共享机制
(3)是一种封装机制 (4)是对象的模板,对象承袭类中的数据和方法
3.1.5 类的定义与实现 一、类的定义—一个类中数据成员和成员函数的说明; 二、类的实现—成员函数的实现,三种方式: 1、类的定义和实现在同一个文件中,且都在类定义中完成; 2、类的定义和实现在同一个文件中,函数的实现放在类外完成; 3、类的定义和实现在不同的文件中。 三种方式可混合使用。
不同类型质子的化学位移范围
不同类型质子的化学位移范围
不同类型的质子在化学位移上具有不同的范围。
以下是一些常见类型质子的化学位移范围:
1. 甲基质子(CH3):通常在0.8到
2.5 ppm的范围内。
2. 亚甲基质子(CH2):通常在1.2到2.8 ppm的范围内。
3. 亚甲质子(CH):通常在1.5到3.0 ppm的范围内。
4. 芳香质子(Ar-H):通常在6.5到9.0 ppm的范围内。
5. 羟基质子(OH):通常在1.5到5.0 ppm的范围内。
6. 醛、酮质子(C=O):通常在2.0到3.5 ppm的范围内。
需要注意的是,这些范围只是一般性的规律,实际上每种化合物的质子化学位移范围会受到其他因素的影响,如分子结构、相邻基团的影响等。
因此,在具体实验中,还需要通过比对实验数据和已有的文献数据来准确确定质子的化学位移范围。
糠酸莫米松一水合物结构式_解释说明
糠酸莫米松一水合物结构式解释说明1. 引言1.1 概述糠酸莫米松一水合物是一种重要的化合物,属于糖皮质激素类药物。
它是由糠酸和莫米松组成,并通过与水分子结合形成一水合物。
这种化合物在医药领域中具有广泛的应用和重要的意义。
1.2 文章结构本文将从以下几个方面对糠酸莫米松一水合物进行详细解释说明。
首先,我们将对该化合物的结构式进行概述,并进行结构分析,以了解其化学成分和特点。
然后,我们将探讨该化合物的物理性质,包括溶解性、稳定性等方面的特征。
随后,我们将重点介绍糠酸莫米松一水合物在医药领域中的应用,并对其功效和副作用进行分析。
最后,我们将探讨糠酸莫米松一水合物与其他药物之间的关系。
1.3 目的本文旨在向读者全面介绍糠酸莫米松一水合物的结构、性质、应用以及与其他药物的关系,以增加对该化合物的理解。
通过深入研究和分析,本文旨在揭示糠酸莫米松一水合物在医药领域中的重要意义,并为进一步相关研究提供指导和展望。
2. 糠酸莫米松一水合物结构式2.1 概述糠酸莫米松一水合物是一种药物,其化学名称为(11β,16α)-21-(乙氧羰基)-9-氟-11-羥孕四烯-3,20-二酮17-(1-羧基)-2-磺基吡咯二酮的一水合物。
它被广泛用于医药领域,并具有广泛的应用和意义。
2.2 结构分析糠酸莫米松一水合物的结构式如下所示:CH3(CH2)7COOH O\CH=CH H HO H O-H CH3 C---C || || ||/ \\ / F ||CH3 C COOH O=O通过结构分析可知,该化合物由多个原子团组成,包括乙氧羰基、乙酸甲酯、氟、羟基、磺氧基等。
其中,糠酸莫米松分子中含有两个环(21碳和4环),其中4环上还含有一个乙氧羰基。
此外,糠酸莫米松分子的结构中还存在着一水合物,即与一个水分子结合形成稳定的化合物。
2.3 物理性质糠酸莫米松一水合物具有一些特殊的物理性质。
其外观为白色结晶性粉末,并且可溶于水和氯仿等溶剂中。
ch3(1) 数据类型、运算符与表达式
基本型:以int 说明,占用2字节。如:int i,sum; 短整型:以short int 或short说明,占用2字节。如:short s,sum; 长整型:以long int 或long说明,占用4字节。如:long l,sum; 无符号型(存放没有符号的整数) 无符号整型:以unsigned int或unsigned说明,占用2字节。 如:unsigned ui,sum; 无符号短整型:以unsigned short说明,占用2字节。 如:unsigned short us,sum; 无符号长整型:以unsigned long说明,占用4字节。 如:unsigned long ul,sum;
3. 整型变量的定义
例如: int a,b; long num,i,j;
unsigned short c,d;
§3.4 整型数据 一、整型常量 二、整型变量
4. 整型数据的溢出
在Turbo C(或Turbo C++)中, 一个int型的变量的最大充许 值为32767,如果再加1,会如 何?
例3-3:整型数据的溢出 #include <stdio.h> void main() { int a,b; a=32767; b=a+1; printf(“a=%d,b=%d\n”,a,b); } a=32767,b=-32768 32767 -32768
0 1 11 11 11 11 11 11 11 1 0 00 00 00 00 00 00 00
§3.4 整型变量 一、整型常量 二、整型变量 三、整型常量的类型
值在-32 768~+32 767范围内,认为是int型 值在-2 147 483 648~+2 147 483 647内,认为是int型
32位实数对应数据类型
32位实数对应数据类型
char :1个字节(不变);
*(指针变量):4个字节(32位机的寻址空间是4个字节。
同理64位编译器)(变化);
short int :2个字节(不变);
int:4个字节(不变);
unsigned int:4个字节(不变);
float:4个字节(不变);
double:8个字节(不变);
long:4个字节(变化);
unsigned long:4个字节(变化*,其实就是寻址空间的地址长度数值);
long long:8个字节(不变);
其他内容补充:
64位对应数据类型:
Char:1个字节(不变);
*(指针变量):8个字节(变化);
short int:2个字节(不变);
int:4个字节(不变);
unsigned int:4个字节(不变);
float:4个字节(不变);
double:8个字节(不变);
long:8个字节(变化);
unsigned long:8个字节(变化*其实就是寻址空间的地址长度数值);
long long:8个字节(不变)。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
例如: 例如:
void main( ) { unsigned int m; 按有符号数输出 m= 65448 65448; printf("\nm=%d %d\n",m); printf("m=%u %u\n",m); }
22
输出结果: 输出结果: m=-88 m=m=65448 m=65448
11
2011-3-1
3.3 整型数据
3.3.1整型常量(整常数)三种形式: 3.3.1整型常量(整常数)三种形式: 整型常量
–十进制整数:由数字0~9和正负号表示.如
ቤተ መጻሕፍቲ ባይዱ
12
123,-
456,0 –八进制整数:由数字0开头,后跟数字0~7表示.如 0123,011 –十六进制整数:由0x开头,后跟0~9,a~f,A~F表示. 如0x123,0Xff 问题: 0123 )10 问题: = ( 0x123 ) 0123 == ( ( 83 )1010 0Xff = 0x123 = (( 291 ))10 10 0Xff = ( 255 )10
程序中用到的数据: 、 程序中用到的数据:r、area、5、3.14 、 、 对数据进行的运算: 对数据进行的运算:* 、=
2011-3-1
分析: 分析:
涉及数据类型 的基本知识 计算机操作处理时,要完成以下工作: 计算机操作处理时,要完成以下工作: 在内存中给半径 r 和运算结果 area 开辟存 储空间,存放它们的值。应该留多大的存 储空间,存放它们的值。应该留多大的存 来存放它们的值? 储空间来存放它们的值 储空间来存放它们的值? 不同, 数据 5 和 3.14 与 r 、area 不同,它们是在 编写程序时就给出确定的值, 编写程序时就给出确定的值,在运算过程 中不会改变。这样的数计算机怎么处理? 中不会改变。这样的数计算机怎么处理? 小数3.14 ,计算机存放时是否 计算机存放时是否 对整数 5 和小数 有区别? 有区别?
10
2011-3-1
变量
语言中,对所有变量必须作强制性定义。 在 C 语言中 , 对所有变量必须作强制性定义 。 即 对变量遵循“先定义,后使用”的原则。 对变量遵循“先定义,后使用”的原则。其主要 目的是: 目的是: 凡未被事先定义的,不能够作为变量名, (1)凡未被事先定义的,不能够作为变量名,这 就能保证程序中变量名的正确使用。 就能保证程序中变量名的正确使用。 (2)便于在编译时为变量正确的分配存储单元。 便于在编译时为变量正确的分配存储单元。 便于检查变量所进行的运算的合法性。 (3)便于检查变量所进行的运算的合法性。
变量名 a 510 变量值 为变量分配的 存储单元
2011-3-1
变量定义
变量定义的一般格式: 变量定义的一般格式: 变量列表; 数据类型说明符 变量列表; 例如: 例如:int i, j; long k, m; float x, y; char ch1, ch2; • 必须使用合法的标识符作变量名 必须使用合法的标识符 标识符作变量名 • 不能使用关键字为变量命名
3.2常量与变量-变量 常量与变量- 常量与变量
8
变量的有关概念 在程序运行过程中,其值改变的数据, 在程序运行过程中,其值改变的数据,称为 变量名。 变量,变量用标识符表示,称为变量名 变量,变量用标识符表示,称为变量名。 变量必须“先定义后使用” 变量必须“先定义后使用” 系统为变量分配存储单元,存储变量的值。 系统为变量分配存储单元,存储变量的值。 编写程序时通过变量名来存、取变量值。 编写程序时通过变量名来存、 变量值。 例如: 例如: 变量a 有变量a 它的值是5 它的值是510
数据类型决定: 1. 数据占内存字节数 2. 数据取值范围 3. 其上可进行的操作
<
>
自定义类型typedef
2011-3-1
3.2常量与变量 3.2常量与变量
标识符——用来标识变量、常量、函数等的字符序列。 用来标识变量、常量、函数等的字符序列。 标识符
标识符的构成规则:只能由字母、数字、 标识符的构成规则:只能由字母、数字、下划 字母 组成, 线组成,且第一个字母必须是字母或下划线的 字符串。 语言中大小写敏感 字符串。在c语言中大小写敏感;并且不能使 语言中大小写敏感; 用关键字。 用关键字。 长度:最长32个字符 长度:最长 个字符 命名原则: 命名原则: 例:判断下列标识符号合法性 – 见名知意 sum Sum M.D.John day Date 3days – 不宜混淆 如l与I, #33 0 lotus_1_2_3 与 与 student_name o与
C 程序设计
第3 章 数据类型、 数据类型、运算符和表达式
西南大学 计算机与信息科学学院
本章主要内容
本章介绍C语言的基础,包括: 本章介绍 语言的基础,包括: 语言的基础 – 数据类型 – 运算符和表达式 程序设计的基本知识 算法+数据结构 程序 = 算法 数据结构
通常程序要对数据进行操作处理: 通常程序要对数据进行操作处理: 程序要对数据进行操作处理 – 处理的对象是数据 处理的对象是数据 – 通过运算符和表达式进行操作 通过运算符和表达式 运算符和表达式进行操作
16
问题: 问题:
为什么要采用补码? 为什么要采用补码? 如何表示? 如何表示?
2011-3-1
计算机中正、 计算机中正、负数的表示
例如: 例如:109 =(1101101)2 要区别:+ :+109 要区别:+109 和 -109 方法是: 方法是:将符号也数码化 即: 正的符号 +用 0 表示 负的符号 -用 1 表示 ∴ 计算机中的数表示方法是: 计算机中的数表示方法是: 符号位+二进制数值( 为例) 符号位+二进制数值(以 8bit 为例) +109 → +110 1101 → 0110 1101 -109 → -110 1101 → 1110 1101
9
2011-3-1
变量的初始化: 变量的初始化:
允许在说明变量的时候对变量赋初值。 允许在说明变量的时候对变量赋初值。 例如: 例如:int a = 5, b = 10 + 2; double x = 23.568, y ; char ch1 = 'a', ch2 = 66, ch3 = '\142'; 表示定义变量并对变量存储单元赋值。 表示定义变量并对变量存储单元赋值。 错误的初始化: 错误的初始化: int a = 3 + b, b = 5; ; float m = n = 23.16; ;
4
2011-3-1
3.1 C语言的数据类型
整 型
5 短整型short 短整型 整型int 整型 长整型long 长整型
本章讨论 基本类型数据
基本类型
实型
单精度型float 单精度型 双精度型double 双精度型 字符类型char 字符类型 数组
C 数 据 类 型
结构体struct 构造类型 共用体union 枚举类型enum 指针类型 空类型void
char a>b _above a>b > $123
6
2011-3-1
3.2常量与变量 常量与变量 常量
定义:程序运行时其值不能改变的量(即常数) 定义:程序运行时其值不能改变的量(即常数) 分类: 分类:
–符号常量:用标识符代表常量 符号常量:
7
<
定义格式: 定义格式: #define 符号常量举例(ch3_1.c) 符号常量 常量 例 如 #define 一般用大写字母 PRICE 30 #define PRICE 30 是宏定义预处理命令,不是C语句,后面没有“ 是宏定义预处理命令,不是C语句,后面没有“;” main() 运行结果:total=300 带来的好处 { –直接常量: 直接常量: int num,total; num=10; 整型常量 total=num*PRICE; 实型常量 printf("total=%d",total); 字符常量 > } 字符串常量 2011-3-1
13
<
>
2011-3-1
3.3.2 整型变量
整型数据在内存的存储 整型变量的分类 整型变量的定义和使用
14
2011-3-1
1、整型数据在内存的存储
1.整型数据在内存中的存放形式 1.整型数据在内存中的存放形式 数据在内存中是以二进制形式存放。 数据在内存中是以二进制形式存放。
例子1 例子1: main( ){ int i; i = 10; printf( “ i= %d \n” , i ); } i i
18
解决的方法是: 解决的方法是: 使用反码 补码的表示方法 反码或 的表示方法( 使用反码或补码的表示方法(按前述 表示的编码称为原码),即能将减法一律 原码), 表示的编码称为原码),即能将减法一律 转换为加法。 转换为加法。
2011-3-1
原码、 原码、反码和补码
正数:原码、反码、 正数:原码、反码、补码相同 – 符号位为0,数值为对应的二进制数。 符号位为0 数值为对应的二进制数。 +109 [01101101]原 = [01101101]反 = [01101101]补 [0 [0 负数: 负数: –原码符号位为1,数值为绝对值的二进制 原码符号位为 符号位为1 [11101101]原 -109 数。 –反码符号位为1,数值为绝对值的二进制 反码符号位为 符号位为1 数各位变反。 [10010010]反 数各位变反。 -109 –补码符号位为1,数值为绝对值的二进制 补码符号位为 符号位为1 数各位变反加1 数各位变反加1。-109 [10010011]补
2
2011-3-1
3
【例】计算圆的面积,半径为 5 cm。 计算圆的面积, 。 程序如下: 程序如下: