nullnull C++程序
谭浩强编著
清华大学出版社
课件制作:福建师范大学 Jerryhuangnull第一章C++概述 C++语言发展历史 自从1946年第一台电子数字计算机ENIAC问世以来,随着计算机应用领域的不断扩大,促进了计算机技术的高速发展,尤其是近年来计算机的硬件和软件都是日新月异。作为应用计算机的一种工具—程序设计语言,得到不断的充实和完善。每年都有新的程序设计语言问世,老的程序设计语言不断地更新换代。 null20世纪60年代,Martin Richards为计算机软件人员在开发系统软件时,作为记述语言使用而开发了BCPL语言(Basic Combined Programming Language)。1970年,Ken Thompson在继承BCPL语言的许多优点的基础上发明了实用的B语言。到了1972年,贝尔实验室的Dennis Ritchie和Brian kernighan在B语言的基础上,作了进一步的充实和完善,设计出了C语言。当时,设计C语言是为了编写UNIX操作系统的。以后,C语言经过多次改进,并开始流行。C++是在C语言的基础上发展和完善的,而C是吸收了其它语言的优点逐步成为实用性很强的语言。nullC语言的主要特点是:
1、C语言是一种结构化的程序设计语言,语言本身简洁、使用灵活方便。既适用于设计和编写大的系统程序,又适用于编写小的控制程序,也适用科学计算。2、它既有高级语言的特点,又具有汇编语言的特点。运算符丰富,除了提供对数据的算术逻辑运算外,还提供了二进制的位运算。并且也提供了灵活的数据结构。用C语言编写的程序表述灵活方便,功能强大。用C语言开发的程序,其结构性好,目标程序质量高,程序执行效率高。null3、程序的可移植性好。用C语言在某一种型号的计算机上开发的程序,基本上可以不作修改,而直接移植到其它型号和不同档次的计算机上运行。4、程序的语法结构不够严密,程序设计的自由度大。这对于比较精通C语言的程序设计者来说,可以设计出高质量的非常通用的程序。但对于初学者来说,要能比较熟练运用C语言来编写程序,并不是一件容易的事情。与其它高级语言相比而言,调试程序比较困难。往往是编好程序输入计算机后,编译时容易通过,而在执行时还会出错。但只要对C语言的语法规则真正领会,编写程序及调试程序还是比较容易掌握的。null随着C语言应用的推广,C语言存在的一些缺陷或不足也开始流露出来,并受到大家的关注。如:C语言对数据类型检查的机制比较弱;缺少支持代码重用的结构;随着软件
规模的扩大,难以适应开发特大型的程度等等。null为了克服C语言本身存在的缺点,并保持C语言简洁、高效,与汇编语言接近的特点,1980年,贝尔实验室的Bjarne Stroustrup博士及其同事对C语言进行了改进和扩充,并把Simula 67中类的概念引入到C中。并在1983年由Rick Maseitti提议正式命名为C++(C Plus Plus)。后来,又把运算符的重载、引用、虚函数等功能加入到C++中,使C++的功能日趋完善。
当前用得较为广泛的C++有:VC++ (Visual C Plus Plus)、 BC++(Borland C Plus Plus)、AT&T C++等。null简单的C++程序介绍高级语言编译过程源程序
(文本文件)
*.CPP目标文件
(二进制文件)
*.OBJ可执行文件
(二进制文件)
*.EXE库文件
(各种函数)在Vitual C++系统中,可直接从源程序编译连接至可执行程序,但依然要生成*.OBJ及*.EXE这两个文件。F7compilelinknull一个简单的C++程序#include
void main(void )
{ cout<<“I am a student.\n”; //输出字符串
}主函数函数体开始函数体结束输出流,在屏幕上打印引号内的字符串分号,一条完整语句的结束符本程序编译执行后,在DOS屏幕上打印出
I am a student.包含文件注释或说明null编译过程:
1)启动Visual C++,选择“文件”菜单中的“新建”命令,选择“文件”标签中的“C++ Source File”选项。
2)选择源程序存放的目录和输入源程序名,单击“确定”。
3)在编辑器中编写源程序。
4)单击F7或“编译”中的“重建全部”编译源程序,若编译通过,单击“执行”,在DOS屏上看结果,任按一键返回编辑器。null启动VC++编译系统nullVC++编译系统界面单击“File”菜单中“New”命令null选择“Files”选项卡选择C++源文件命令输入文件名输入文件存放位置单击选择驱动器选择驱动器或目录nullC++源文件编辑界面输入C++源代码null可以将此源代码另起文件名存盘null选择编译命令,将源文件.cpp生成.obj文件null如果编译出错,会出现提示信息,指出错误的位置及种类错误所在行错误的原因null双击错误所在行光标移到该行null生成可执行文件通过后单击该命令运行程序null运行结果显示在DOS屏上注意:不可以在软盘上运行程序!应该把保存在软盘中的源文件拷贝到硬盘的目录中再运行!null源程序所在目录未编译前,只有一个源程序null编译运行后,出现众多附加文件同时,产生一个子目录DebugnullDebug目录中,有obj和EXE文件null#include
void main(void)
{
cout << “i=”; //显示提示符
int i; //说明变量i
cin >>i; //从键盘上输入变量i的值
cout << “i的值为:” <
#define PRICE 30 //常量,在程序中保持不变
void main(void)
{ int num, total; //定义变量,在内存中开辟区间
num=10; //变量赋值,10为常量
total=num*PRICE;
cout<<“total=“<
void main(void)
{
int int10,int8,int16; //定义3个整型变量
int10=10; //默认为十进制
int8=010; //八进制
int16=0x10; //十六进制
cout<<"int10="<
void main()
{ unsigned short a;
short int b= -1;
a=b;
cout<<"a="<
void main(void)
{ float a, b;
double c, d;
a=0.01;
b=3.45678e-2;
c=3.45678e-2;
d=9.7654e-5;
cout<<"a="<决定有效数字,即数字的精度。
J 表示指数(阶码)。
R 是基数,可取2,4,8,16等,对具体机器而言,基数取好后,就不能再变了。
数有正有负, 所以设置数符; 阶码亦有正负, 所以设置阶符null一般用4个字节表示一个浮点数,也有用8个字节表示的。字长一定,尾数越多,精度越高;阶码越多,范围越大。
当计算机中出现小于机器所能表示的最小数时,机器只能当零来处理,当出现超过机器所能表示的最大数时,出现溢出现象,一旦出现溢出,就会停止运算。定点数,浮点数均会出现溢出现象。null字符型数据(char)字符型数据实际上是作为整型数据在内存中存储的。
计算机是以字符编码的形式处理字符的,因此,我们在计算机内部是以ASCII码的形式表示所有字符的。所以7位二进制数即可表示出一个字符,我们用一个字节的容量(8位)存储一个字符。例如:字符A的ASCII码为0x41或65,在内存中表示为:在程序中表示为:
char grade ;//定义一个字符型的变量空间(1个字节)
grade=‘A’; //必须用‘ ’表示,否则易与标识符混同 ‘ ’内括起来的字符表示该字符的ASCII码。null进一步,由于在内存中的形式与整型数据相同,所以,可以直接用其整型值给变量赋值。char grade;
grade=65;以下的赋值形式均是等同的。
grade='A'; grade=65 ; grade=0x41; grade=0101;#include
void main(void)
{
char a,b;
a=‘A’; //输入ASCII码
b=65; //输入十进制数
cout<<"a="<
void main(void)
{
char c1,c2,c3,c4;
char n1,n2;
c1='a'; //字符常量
c2=97; //十进制
c3='\x61'; //转义字符
c4=0141; //八进制
cout<<"c1="<
#define PI 3.14156
#define S "China"
void main(void)
{
const float pi=3.14156; //变量作为常量使用
cout<<"PI="< <= >= = = !=
= = 与 =
a=5; 赋值运算 a= =5;判断是否相等< > <= >= 的优先级大于= = !=3. 算术运算符的优先级大于关系运算符的优先级null关系表达式:用关系运算符将表达式连接起来称为关系表达式。其值非真即假。在C++语言中,用非0代表真,用0表示假。关系表达式的结果只有两个,真为1,假为0。 a=2 b=3 c=4
a>2
a>b+c
a= =2 a= ='a'
a>'a'
b=a= =2'a'>'A'
b= ='a'+1
c-a= =a001001101null 逻辑运算符 运算符 与&& 或 || 非! A B 结果
0 0 0
0 1 0
1 0 0
1 1 1
有0出0,全1出1
A,B同时成立&&A B 结果
0 0 0
0 1 1
1 0 1
1 1 1
有1出1,全0出0
A或B有一个成立| |A 结果
0 1
1 0
有0出1,
有1出0!null江苏籍的男生
江苏籍的学生和所有男生
非江苏籍的学生江苏籍&&男生例如:两个条件:江苏籍 男生江苏籍||男生!江苏籍注意:
1.优先级:!&&| |
!算术关系逻辑赋值逗号null3.不可写为 13 && 2 || 8<4-!04.当前面的表达式可以得出整个表达式的结果时,不必再求后面的表达式。a&&b&&c 当a为0时,表达式为0,不必求b与c。a||b||c 当a为1时,表达式为1,不必求b与c。nullx=4 y=5
i= ++x= =5 || ++y= =6x=5 y=5 i=1i= x++= =5&& y++= =6x=5 y=5 i=0判断某年是否为闰年
1)能被400整除
2)能被4整除,不能被100整除 (2200年不是)year%400= =0year%4= =0&& year%100!=0(year%400= =0) || (year%4= =0&&year%100!=0)null当c=4时,以下的值各多少?
(c=1)&&(c=3)&&(c=5)
(c= =1)||(c= =2) || (c= =5)
(c!=2) && (c!=4) &&(c>=1)&&(c<=5)100nullsizeof()运算符 sizeof()运算符是一个单目运算符,用于计算某一个操作数类型的字节数。其格式为:
sizeof(<类型>)sizeof(int) //其值为4
sizeof(float) //其值为4
sizeof(double) //其值为8
sizeof(char) //其值为1null逗号运算符和逗号表达式表达式1,表达式2,表达式3,…,表达式n
顺序求解,结果为最后一个表达式的值,并且优先级最低。a=(3+4, 5*6, 2+1); a=3a=3*3, a+6, a+7;16(a=3*5, a*4), a+520a=9a=15null下列语句中表达式中i, j的值各为多少
1、int i=0, j=0; 2、 int i=0, j=1;
i=3, (j++)+i ; i+=j*=3;
3、int i=1, j=0; 4、int i=1, j=1;
j=i=((i=3)*2); i+=j+=2;i=3,j=1i=3,j=3i=6,j=6i=4,j=3null各类数值型数据间的混合运算整型、实型、字符型数据间可以混合运算。10+'a'+1.5-87.65*'b'在进行运算时,不同类型的数据要先转换成同一类型的数据再进行运算。
转换规则如下:null第三章 简单的输入输出null 输入语句:cin程序在执行期间,接收外部信息的操作称为程序的输入;而把程序向外部发送信息的操作称为程序的输出。在C++中没有专门的输入输出语句,所有输入输出是通过输入输出流来实现的。 null要使用C++提供的输入输出时,必须在程序的开头增加一行:
#include
即包含输入输出流的头文件“iostream.h”。有关包含文件的作用,在编译预处理部分(第五章)作详细介绍。null 输入十进制整数和实数cin >> <变量名1>《 >> <变量名2> ...... 》(举例说明)int a,b;
cin>>a>>b; //程序运行至此停下,等待从键盘输入变量值键盘输入:3 5
或:3 5 均可。输入语句自动过滤空白字符。3键盘5键盘null浮点型数据同整型数据一样。float c,d;
cin>>c>>d;char ch1,ch2;
cin>>ch1>>ch2;若输入:ab 则ch1为a, ch2为b。若输入:a b 则ch1为a, ch2为b。字符型变量过滤空白字符。cin格式过滤空白字符nullfloat a;
int i1,i2;
char ch1,ch2;
cin>>i1>>a>>i2>>ch1>>ch2;输入:34 5.678 1a bi2:1在缺省的情况下,cin自动跳过输入的空格,换言之,cin不能将输入的空格赋给字符型变量,同样地,回车键也是作为输入字符之间的分隔符,也不能将输入的回车键字符赋给字符型变量。 a:5.578i1:34ch1:ach2:bnull若要把从键盘上输入的每一个字符,包括空格和回车键都作为一个输入字符赋给字符型变量时,必须使用函数cin.get()。其格式为:
cin.get(<字符型变量>);cin.get()从输入行中取出一个字符,并将它赋给字符型变量。这个语句一次只能从输入行中提取一个字符。char c1;
cin.get(c1);nullchar ch1,ch2,ch3;
cin.get(ch1);
cin.get(ch2);
cin.get(ch3);输入:A B则:ch1:A并且在输入缓冲区中保留回车键。 ch2:空格ch3:B空格的ASCII码为32ch2null输入十六进制或八进制数据 在缺省的情况下,系统约定输入的整型数是十进制数据。当要求按八进制或十六进制输入数据时,在cin中必须指明相应的数据类型:hex为十六进制;oct为八进制;dec为十进制。 nullint i,j,k,l;
cin>>hex>>i; //指明输入为十六进制数
cin>>oct>>j; //指明输入为八进制数
cin>>k; //输入仍为八进制数
cin>>dec>>l; //指明输入为十进制数
当执行到语句cin时,若输入的数据为:
11 11 12 12结果:i:17j:9k:10l:12null使用非十进制数输入时,要注意以下几点:
1、八进制或十六进制数的输入,只能适用于整型变量,不适用于字符型变量,实型变量。2、当在cin中指明使用的数制输入后,则所指明的数制一直有效,直到在接着的cin中指明输入时所使用的另一数制为止。如上例中,输入k的值时,仍为八进制。null3、输入数据的格式、个数和类型必须与cin中所列举的变量类型一一对应。一旦输入出错,不仅使当前的输入数据不正确,而且使得后面的提取数据也不正确。cin>>a,b; cin>>a b; cin>>ab; int a, b;cin>>a>>b; null输出数据 cout
与输入cin对应的输出是cout输出流。当要输出一个表达式的值时,可使用cout来实现,其一般格式为:
cout << <表达式> 《<< <表达式>......》;
其中运算符“<<”称为插入运算符,它将紧跟其后的表达式的值,输出到显示器当前光标的位置。 nullint a=6;
float f1=12.4;
char s1[ ]=“abcd”;
cout<int i1=4,i2=5;
float a=3.5;
cout<<“a*i1=“<办法