C++学习笔记
- 格式:doc
- 大小:78.00 KB
- 文档页数:7
碳族元素预习笔记一、碳族元素通性1、原子结构性质⑴相似性:•外层电子构型:ns²np²气态氢化物的通式:RH4最高价氧化物对应的水化物通式为H2RO3或R(OH)4⑵递变性•+2价化合物主要氧化态稳定性:由上至下逐渐增强+4价化合物主要氧化态稳定性:由上至下逐渐减弱但铅(Ⅱ)化合物稳定性高于铅(Ⅳ),铅(Ⅳ)本身为强氧化剂。
•熔沸点降低(锡和铅反常),单质密度逐渐增大•金属性增强,非金属性减弱,(由于半径不断增大,原子核对外层电子引力变小所致)•最高价氧化物对应水化物的酸性减弱(最高价氧化物对应的酸举个例子解释:碳酸H2CO3。
(HO)2-CO连接一个氧原子,氧原子强吸电子作用导致碳原子电子云密度下降,对应的碳原子同样要从羟基上边多取电子,那么最终结果就是羟基氧原子再把和氢原子公用的电子对拉向自己。
那么此时氢原子是缺电子的,就会很容易电离。
氢原子越缺电子越容易电离;那么对应的中心原子越吸电子,氢原子就越缺电子。
所以从上到下,元素原子电负性减弱,吸电子能力减弱,自然氢离子电离能力减弱,酸性减弱。
)•氢化物的稳定性减弱•第一电离能:由碳至铅逐渐减小(同主族由上至下半径增大,更易失去最外层电子)特殊:锡<铅•熔沸点:由碳至铅逐渐减小(碳、硅为原子晶体,锗、锡、铅为金属晶体)二、元素的成键特性⒈碳:①共价键(sp:CO sp²:乙烯 sp³:甲烷):碳碳,碳氢,碳氧键键能大,稳定,因此碳氢氧可形成多种有机化合物。
②以碳酸盐的形式存在于自然界中2.硅:①硅氧四面体形式存在(石英,硅酸盐矿)②硅硅,硅氧,硅氢键较弱,可形成有机化合物但数量较少3.锡铅:①离子键(+2氧化态,SnO、PbO +4氧化态,SnCl4)②共价键(+4氧化态,SnO、PbO2)二、碳及其化合物1.单质(三种同素异形体)①金刚石:结构:sp³杂化,原子晶体,五个碳原子构成正四面体性质:硬度最大,熔沸点很高(由于其为空间网状结构),无色透明,不导电,化学惰性,但800°C以上与空气反应成CO2②石墨:结构:sp²杂化,层状原子晶体,每层上的碳原子各提供一个含成单电子的p轨道形成大π键层与层之间靠分子见作用力结合在一起。
C#学习笔记(五):while循环和for循环while循环while循环和for循环,可以相互替换,范围和效能⼀样,理解事物的逻辑不⼀样while循环⽤于条件不确定的逻辑for循环⽤于计算次数的逻辑for循环快捷写法,按两下TABi++:for+按两下TABi--:forr+按两下TABfor循环:锁死次数using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;namespace w2d1_for{class Program{static void Main(string[] args){#region for循环//for循环经常⽤来做固定次数,或者是在固定区间的循环//如:写⼀百遍“我要学好C#”//while循环经常来做,某⼀条件或者多条件达成则终⽌的循环//如:直到密码正确才允许登录//for (第⼀表达式(初始表达式);第⼆表达式(条件表达式);第三表达式(增量表达式))//{//循环体//}//在for循环开始之初,会执⾏初始表达式⼀次//在循环体开始前会执⾏条件表达式//如果条件表达式为真,则执⾏循环体完成后,执⾏增量表达式,再问条件表达式,以此循环//否则结束循环//正增长循环,快捷键:for +两下TAB;for (int i = 5; i <= 500; i++)//循环次数500-5+1=496{}//负增长循环,快捷键:forr + 两下TAB;for (int i = 500 - 1; i >= 0; i--){}#endregion#region for循环练习//找出100内所有素数。
素数/质数:只能被1和这个数字本⾝整除的数字,1不是质数,最⼩的质数是2。
//如果你遇到⼀个复杂,要抽象其⼦问题//⼦问题:某⼀个数是不是质数for (int j = 2; j <= 100; j++){int num = j;for (int i = 2; i <= num; i++){if (i == num){Console.WriteLine("{0}是⼀个质数", i);break;}}}}//求100-999之间的⽔仙花数,例如:153 = 1*1*1+5*5*5+3*3*3//取某⼀位等于这个数余这个位的上⼀位,如取百位,余千,然后与本位相除,如百位,除⼀百 //abc = a * a * a + b * b * b + c * c * c;for (int i = 100; i <= 999; i++){int a = (i % 1000) / 100;int b = (i % 100) / 10;int c = (i % 10) / 1;if (i == a * a * a + b * b * b + c * c * c){Console.WriteLine(i);}}#endregion#region 循环⼩练习//求1-100之间所有偶数的和?int count = 1;int sum = 0;for (int i = 1; i <= 100; i++){if (count % 2 == 0){sum += count;}count++;}Console.WriteLine(sum);//求数列 1,1,2,3,5,8,13, ... 的第20位数字是多少?int count1 = 1;Console.WriteLine(count1);int count2 = 1;Console.WriteLine(count2);int count3 = count1 + count2;for (int i = 3; i <= 20; i++){count1 = count2;count2 = count3;count3 = count1 + count2;Console.WriteLine(count3);}//假如⽕星2016年培养学员10万⼈,每年增长80%,请问按此速度增长,//到哪⼀年培训的学员⼈数将达到100万⼈?int year = 2016;float stu = 10f;float rate = 0.8f;while (true){year++;stu += stu * rate;if (stu >= 100f){Console.WriteLine("{0}年培训的学员⼈数将达到100万⼈", year); break;}}//输⼊班级⼈数,然后依次输⼊学员成绩(需提⽰当前是第⼏个学员),计算班//级学员的平均成绩和总成绩。
endl换行符,也是std成员函数4).io流运算cout控制台输出—屏幕上终端窗口,带缓冲<<插入运算符cin控制台输入—键盘>>提取运算符5).名字空间Std:标准c++库所提供一切函数、对象、类型都隶属于std名字空间。
::-作用域限定符---名字空间“的”某个对象。
+= -=名字冲突:看作用域。
同一作用域不可使用相同名字。
----解决方法:成员前加名字空间名,中间::3.名字空间namespace 名字空间名{名字空间成员1;名字空间成员2;//名字空间成员可以是变量、函数、类型}名字空间名::名字空间成员1名字空间合并:同一个名字空间可以分别书写在不同的namespace子句中,只要它们的名字相同,仍然会被编译器识别为同一个名字空间。
Namespace名字空间名{名字空间成员1;}namespace名字空间名{名字空间成员2;}名字空间成员的声明和定义可以分开写,但是定义部分需要借助作用域限定符“::”指明所定义的成员隶属于哪个名字空间。
名字空间指令:using namespace名字空间名;名字空间指令以后的代码,对名字空间中的所有成员可见,可以直接引用,无需作用域限定符。
使用时要注意不要引入新的名字冲突。
名字空间声明:using名字空间名::名字空间成员;名字空间声明用于将名字空间中的特定标识符引入当前作用域,可以省略作用域限定符,直接引用之。
使用时注意不要因此引入新的名字冲突。
无名名字空间:不隶属于任何名字空间的标识符,编译器就将其缺省地放入无名名字空间。
对于无名名字空间中的成员,可以直接使用“::”进行访问。
名字空间允许多层嵌套,访问时需要逐层分解。
可利用名字空间别名简化名字空间嵌套路径的书写形式。
Using只能看里面一层。
4.结构、联合和枚举1)所有的类型关键字在声明变量时都可以省略。
struct Date{ //Date结构名int year; //成员变量(成员表列)(类型说明符成员名)int month;int day;void show(void)//成员函数{}};Int main(void){ //全局变量Date d = {2016,8,2},*e = &d;//e是指向d的指针d.show(); //“.”直接成员访问运算符e->show (); //“->”间接成员访问运算符return 0;}struct Date d = {2016,8,2};//C/C++Date d = {2016,8,2};//C++ //类型关键字省略2)C++中结构体可以包含函数(一个int四个字节,函数不放变量中,放代码区)成员函数的调用,前面要写“.”“->”定义结构体时不能同时初始化!3)C++中增加了匿名联合。
笔记目录第一章:预备知识 (5)1、c++简介 (5)2、程序创建技巧 (5)3、源文件扩展名 (5)第二章:开始学习c++ (5)1、c++代码区分大小写。
(5)2、c++代码结构 (5)3、函数 (6)4、注译 (6)5、c++预处理器和iostream文件 (6)6、头文件名 (6)7、名称空间 (7)8、cout进行c++输出 (7)9、控制符endl (7)10、c++代码格式 (7)C++语句 (7)1、声明语句和变量 (7)2、赋值语句 (7)3、cout的新用法 (8)4、使用cin (8)5、使用cout拼接 (8)6、类简介 (8)7、函数 (8)8、函数原型 (9)9、使用库函数 (10)10、函数变体 (10)12、函数格式 (11)14、复习int main()函数头 (12)15、关键字 (12)16、用户定义有返回值的函数 (13)17、多函数程序中使用using指令 (14)总结 (14)复习题 (14)编程练习 (15)第三章、处理数据 (17)1、简单变量 (17)2、变量名 (18)3、整型 (18)4、整型short、int、long和long long (18)※注译:位与字节 (18)要了解的概念: (19)5、运算符sizeof和头文件limits (20)符号常量-预处理器方式(注译) (21)6、初始化 (21)c++初始化方式 (21)7、无符号类型 (22)8、选择整数类型 (23)9、整型字面值 (24)10、C++如何确定常量的类型 (25)11、char类型:字符和小整数 (26)成员函数cout.put() (27)Char字面值and转义序列 (27)通用字符名 (28)signed char和unsigned char (29)wcha_t (29)C++11新增的类型:char16_t和char32_t (29)12、const限定符(定义符号常量) (30)13、浮点数 (30)书写浮点数 (31)浮点类型 (31)浮点常量 (32)浮点数的优缺点 (33)将类型分类*注译 (33)13、c++算术符 (33)运算符优先级和结合性 (34)除法分支 (34)运算符重载(注译) (34)求模运算符 (35)类型转换 (36)14、总结 (38)15、第三章复习题 (39)16、编程练习 (40)第四章、复合类型 (40)1、数组 (40)3、数组的初始化规则 (42)4、c++数组初始化方法 (42)5、字符串 (43)拼接字符串常量 (43)在数组中使用字符串 (43)字符串输入 (45)每次读取一行字符串输入 (46)混合输入字符串和数字 (47)6、string类简介 (48)C++11字符串初始化 (49)赋值、拼接和附加 (49)String类的其他操作(包含了确定字符数函数) (50)String类I/O (50)其他形式的字符串面值 (52)7、结构简介 (52)在程序中使用结构 (53)C++结构初始化 (55)结构可以将string类作为成员吗 (56)其他结构属性 (56)结构数组 (56)结构中的位字段 (57)9、共用体 (57)10、枚举 (58)设置枚举量的值 (59)枚举的取值范围 (59)11、指针和自由存储空间 (59)声明和初始化指针 (61)指针的危险 (62)指针和数字 (63)使用new来分配内存 (63)使用delete释放内存 (64)使用new来创建动态数组 (65)12、指针、数组和指针算术 (67)指针小结 (69)指针和字符串 (71)使用new创建动态结构 (73)第一章:预备知识1、c++简介c面向过程,c++面向对象。
《C++ Primer》第17章学习笔记第17章:用于大型程序的工具——异常处理,命名空间,多重继承与虚继承@学习摘录204:概念——大规模编程对程序设计语言的要求往往比小程序员团队更高。
——1. 更严格的正常运转时间以及更健壮的错误检测和错误处理。
——2. 能够用各种库(可能包含独立开发的库)构造程序。
——3. 能够处理更复杂的应用概念。
第一节:异常处理@学习摘录205:异常处理的作用——通过异常我们能够将问题的检测和问题的解决分离,这样程序的问题检测部分可以不必了解如何处理问题。
@学习摘录206:抛出类型的异常——异常是通过抛出(throw)对象而引发(raise)的。
被选中的处理代码是调用链中与该对象类型匹配且离抛出异常位置最近的那个。
——执行throw的时候,不会执行跟在throw后面的语句,而是将控制从throw转移到匹配的catch.@学习摘录207:被抛出的对象——被抛出的对象将会自动转换为一个指针,不存在数组或函数类型的异常。
——如果抛出一个数组,被抛出的对象转换为指向数组首元素的指针。
——如果抛出一个函数,函数被转换为指向该函数的指针。
@学习摘录208:异常对象——在处理异常的时候,抛出异常的块中的局部存储不存在了。
——因为在处理异常的时候会释放局部存储,所以被抛出的对象就不能再局部存储了,而是用throw表达式初始化一个称为异常对象的特殊对象。
——异常对象将传给对应的catch,并且在完全处理了异常之后撤销。
——当抛出一个表达式的时候,被抛出对象的解态编译时类型将决定异常对象的类型。
@学习摘录209:异常与指针——用抛出表达式抛出静态类型时,比较麻烦的一种情况是,在抛出中对指针解引用。
——抛出指针的时候,必须确定进入处理代码时指针所指向的对象存在。
——如果抛出指向局部对象的指针,而且处理代码在另一函数中,则执行处理代码时指针所指向的对象将不再存在。
——抛出指针通常是个坏主意:抛出指针要求在对应处理代码存在的任意地方存在指针所指向的对象。
C语言谭浩强版笔记第一章程序设计和C语言1、计算机能直接识别和接受的二进制代码称为机器指令,机器指令的集合就是该计算机的机器语言。
2、语言的发展历史:①机器语言②符号语言③高级语言3、高级语言的发展:①非结构化语言②结构化语言③面向对象的语言4、C语言的祖先是BCPL语言5、在字符串中的//和/*都不作为注释的开始。
而是作为字符串的一部分。
【但是在vc++6.0中//显示编译错误】6、不要以为在max函数中求出最大值z后就会自动地作为函数值返回调用处,必须用return语句指定将哪个值作为函数值。
也不要不加分析地在所有函数后面都写上return 07、一个程序由一个或多个源程序文件组成8、全局声明:即在函数之外进行的数据声明,在函数外面声明的变量称为全局变量。
例如把int a,b,sum;放到main函数的前面9、函数是C程序的主要组成部分,编写C程序的工作主要就是编写一个个函数10、一个C语言程序是由一个或多个函数组成的,其中必须有且只有一个main函数11、一个小程序只包含一个源程序文件,在一个源程序文件中包含若干个函数(其中一个为main函数),若程序规模太大,可以使一个程序包含若干个源程序文件,每个源程序文件又包含若干个函数【一个源程序文件就是一个程序模块,一个程序分成若干个程序模块】12、在进行编译时是以源程序文件为对象进行的【分别对各源程序文件进行编译得到相应的目标程序,然后再将这些目标程序连接成为一个统一的二进制可执行程序】13、C语言的这种特点使得容易实现程序的模块化14、一个函数名后面必须跟一对圆括号,括号内写函数的参数名及其类型。
如果函数没有参数,可以写void或空括号【如int main(void)或int main()】15、void dump(){}它是一个空函数,但是是合法的16、程序总是从mian函数开始执行的,不管位置在哪儿17、程序中对计算机的操作是由函数中的C语句完成的18、二进制目标程序在visual C++中的后缀为.obj19、可执行程序在visual C++中的后缀为.exe20、一个源程序经过编译后得到的目标程序要经过连接阶段与函数库进行连接才能生成可执行文件21、程序设计的任务:①问题分析②设计算法③编写程序④对源程序进行编辑、编译和连接⑤运行程序,分析结果⑥编写程序文档第二章算法1、对数据的描述:在程序中要指定用到哪些数据类型以及这些数据类型和数据的组织形式,这就是数据结构。
C Primer Plus(第五版)学习笔记第一章概览1.1 C语言的起源记住Dennis Ritchie和Ken Thomson。
是在设计UNIX操作系统的时候开发的。
1.2 使用C语言的理由C是一种融合了控制特性的现代语言,而我们已发现在计算机科学的理论和实践中,控制特性是很重要的。
其设计使得用户可以自然地采用自顶向下的规划、结构化的编程,以及模块化的设计。
这种做法使得编写出的程序更可靠、更易懂。
C是一种高效的语言。
C程序往往很紧凑且运行速度快。
C是一种可移植语言。
由于C与UNIX的紧密联系,UNIX系统通常都带有一个C编译器作为程序包的一部分。
Linux中同样也包括一个C 编译器。
C强大而又灵活(计算机世界中经常使用的两个词)。
C面向编程人员的需要。
它允许您访问硬件,并可以操纵内存中的特定位。
它具有丰富的运算符供选择,让您能够简洁地表达自己的意图。
多数C实现都有一个大型的库,其中包含有用的C函数。
这些函数能够处理编程人员通常会面对的许多需求。
C的简洁性与其丰富的运算符相结合,使其可能会编写出极难理解的代码。
没有谁强迫您编写含糊难懂的代码,但存在这样的可能性。
试问,除C之外还有哪种语言存在一年一度的“含糊代码”(ObfuscatedCode)竞赛呢?1.3 C语言的发展方向不管C++和Java这些较新的语言如何流行,C在软件产业仍然是一种重要的技能,在最想获得的技能中,它一般都列在前10名。
特别是在嵌入式系统的编程中,C已开始流行。
也就是说,它将用来为汽车、照相机、DVD播放器和其他现代化设备中逐渐普及的微处理器编程。
同样,C已开始进入长期以来一直属于FORTRAN的科学编程领域。
最后,由于它是一种适合用来开发操作系统的语言,C在Linux的开发中也扮演着重要的角色。
1.4 计算机工作的基本原理CPU的工作非常简单,至少在我们所做的这一简短描述中是这样的。
它从内存中获取一个指令并执行该指令,然后从内存中获取下一个指令并执行。
1. c 语言1.1.1.helloworld文件名:test_pointer.c文件内容:#include <stdio.h>#include <malloc.h>int main(){printf("hello world\n\n");return 0;}编译加运行:[root@localhost c_study]# gcc test_pointer.c ;./a.outhello world1.1.2.获取键盘输入文件名:getKeyboardInptStr.c文件内容:#include <stdio.h>#include <malloc.h> int main(){char *a= malloc(sizeof(char *));char *b= malloc(sizeof(char *));scanf("%s",a);scanf("%s",b);printf("%s \t%s\n",a,b);free(a);free(b);return 0;}编译:gcc getKeyboardInptStr.c -o hello.exe运行[root@localhost tcp_ip]# ./hello.exe abcdddabc ddd[root@localhost tcp_ip]#1.1.2.1.从键盘输入构造数组文件名keyboard_input.c文件内容:#include <stdio.h>#include <malloc.h>int main(){char * strs[4];char *a;int i;for(i=0;i<4;i++){a= malloc(sizeof(char *));scanf("%s",a);strs[i]=a;//printf("%s \t\n",a);//free(a);}printf("=====================================\n");for(i=0;i<4;i++){printf("%s \t\n",strs[i]);}return 0;}1.1.3.读取文件读取文件有两个操作:打开流(fopen)和关闭流(fclose)#include <stdio.h>#include <stdlib.h>#include <malloc.h>int main(int ac,char**av){int exit_status=EXIT_SUCCESS;FILE *input;while( *++av!=NULL){input=fopen(*av,"r");if(input==NULL){perror(*av);exit_status=EXIT_FAILURE;continue;}if(fclose(input)!=0){perror("fclose");exit(EXIT_FAILURE);}}return exit_status;}1.1.3.1.打开文件流1.1.3.1.1.ungetc 用法文件名:ungetc_test.c文件内容:#include<stdio.h>#include<ctype.h>int main(){int value;int ch;value=0;while((ch=getchar())!=EOF && isdigit(ch)){value=value*10;value+=ch-'0';}//ungetc(ch,stdin);printf("%d\n",value);ch=getchar();printf("last char is %c\n",ch);return value;}若注释掉红色部分:[root@localhost read_file]# gcc ungetc_test.c;echo 234abc|./a.out 234last char is b否则:[root@localhost read_file]# gcc ungetc_test.c;echo 234abc|./a.out 234last char is a1.1.3.2.关闭流1.1.3.3.读取文本文件文件名称:read_file03.c文件内容:#include <stdio.h>#include <stdlib.h>#include <malloc.h>int main(){int value;int ch;char *input_file="ab.txt";FILE *input;input=fopen(input_file,"r");while((ch=fgetc(input))!=EOF){printf("%c",ch);}return 0;}1.2.指针1.2.1.取地址和取值取地址:&取值:*1.2.1.1.取地址int age=23;int *age_adrr=&age;1.2.1.2.取值参阅取地址。
【C语⾔C++编程学习笔记】基础语法,第⼀个简单的实例编程⼊门教程!C语⾔/C++编程学习:⼀个简单的实例如果你能知道该程序将会在显⽰器上显⽰⼀些内容,那说明你还是知道⼀些的!确实如此,但所要显⽰的确切内容不是显⽽易见的,所以请运⾏程序来观看结果。
⾸先,⽤你熟悉的编辑器建⽴⼀个上⾯这个样的程序,然后给这个程序取⼀个名字,并以 .c 作为结尾以满⾜所在系统对⽂件名格式的要求。
例如,你可以把它命名为 helloworld.c。
现在编译并运⾏该程序。
如果⼀切运⾏正常,其显⽰结果为:实例简单说明◆ #include ←包含另⼀个⽂件这是程序的第⼀⾏。
它的作⽤相当于你在⽂件中的这⾏所在的位置键⼊了⽂件 stdio.h 的完整内容。
实际上,它是⼀种剪切和粘贴操作,这样可以⽅便地在多个程序间共享公⽤的信息。
#include 语句是 C预处理指令的⼀个例⼦。
通常,C 编译器在编译前要对源代码做⼀些准备⼯作;这称为预处理。
stdio.h ⽂件作为所有 C编译包的⼀部分提供,它包含了有关输出输⼊函数的信息以供编译器使⽤。
这个名字代表标准输⼊输出头⽂件。
我们称之为头⽂件,C语⾔中通常都带有许多头⽂件。
◆ int main () ←函数名接下来的这⾏代码声明了⼀个 main函数。
⼀个 C语⾔程序总是从称为 main()的函数开始执⾏的。
你可以对你所⽤的其他函数任意命名,但是 main()必须是开始的函数,所以说,main()函数在程序中是唯⼀的。
那么圆括号的功能呢?它们表明 main()是⼀个函数。
以后你将了解到更多的函数。
但现在,请你记住这个函数是 C程序的基本模块。
int 指明了 main()函数的返回类型。
这意味着 main()函数返回值的类型是整数。
返回到哪⾥呢?返回给操作系统。
如果浏览⽼版本的 C代码,你将发现程序常常以:main()这种形式开始。
C90标准勉强允许这种形式,但是 C99标准不允许。
因此即使你当前的编译器允许,也不要这么做,请注意规范。
「C#学习笔记」三点定位算法⾃⼰写的,可能还有很多不⾜,看着哪⾥不对的求提出,我改~先上代码,然后解释我的想法1namespace ThreePointOrientation2 {3class Program4 {5struct Point6 {7public int x;8public int y;9 }10static Point ThreePointOrientation(Point A, Point B, Point C, int lenAZ, int lenBZ, int lenCZ)11 {12 Point A1, B1, C1, Min, B2, Z2, Z1, ZZ1, inA1B1;14//115if (A.x <= B.x && A.x <= C.x)16 { A1 = A; B1 = B; C1 = C; }17else if (B.x <= A.x && B.x <= C.x)18 { A1 = B; B1 = C; C1 = A; }19else20 { A1 = C; B1 = A; C1 = B; }21 Min = A1;22//223 A1.x = 0; A1.y = 0;24 B1.x -= Min.x; B1.y -= Min.y;25 C1.x -= Min.x; C1.y -= Min.y;26//327int lenAB = (int)System.Math.Sqrt(B1.x*B1.x + B1.y*B1.y);32 B2.x = lenAB; B2.y = 0;33//434 Z2.x = (lenAZ * lenAZ + lenAB * lenAB - lenBZ * lenBZ) / (2 * lenAB);35 Z2.y = (int)System.Math.Sqrt(lenAZ*lenAZ-Z2.x*Z2.x);36//537float tanBAB = (float)B1.y / (float)B1.x;38float tanCAC = (float)Z2.y / (float)Z2.x;39float tanCAB2;40if (B1.y >= 0)41 tanCAB2 = (tanBAB+tanCAC)/(1-tanBAB*tanCAC);42else43 tanCAB2 = (tanCAC-tanBAB)/(1+tanCAC*tanBAB);44//645 Z1.x = (int)((float)lenAZ / (System.Math.Sqrt(tanCAB2 * tanCAB2 + 1)));46 Z1.y = (int)(tanCAB2 * Z1.x);47//748 inA1B1.x = (A1.x + B1.x) / 2;49 inA1B1.y = (A1.y + B1.y) / 2;50//851 ZZ1.x = inA1B1.x * 2 - Z1.x;52 ZZ1.y = inA1B1.y * 2 - Z1.y;53//954int lenZZ1C1 = (int)System.Math.Sqrt(System.Math.Pow(ZZ1.x - C1.x, 2) + System.Math.Pow(ZZ1.y - C1.y, 2)); 55int lenZ1C1 = (int)System.Math.Sqrt(System.Math.Pow(Z1.x - C1.x, 2) + System.Math.Pow(Z1.y - C1.y, 2));56if((lenZZ1C1-lenCZ)<(lenZ1C1-lenCZ))57 Z1 = ZZ1;58//1059 Z1.x += Min.x;60 Z1.y += Min.y;6162return Z1;63 }64static void Main(string[] args)65 {66 Point a, b, c, z;67int az, bz, cz;68 a.x = -5;69 a.y = -5;70 b.x = 47;71 b.y = 25;72 c.x = -5;73 c.y = 55;74 az = 34;75 bz = 34;76 cz = 34;77 z = ThreePointOrientation(a, b, c, az, bz, cz);78 Console.WriteLine("x = {0}, y = {1}\n", z.x, z.y);79 Console.ReadKey();80 }81 }82 }主要就是函数Point ThreePointOrientation(Point A, Point B, Point C, int lenAZ, int lenBZ, int lenCZ);A,B,C是已知的三点,lenAZ,lenBZ,lenCZ分别是三点到要求的点的距离,函数返回要求的点的坐标。
在C++中把一组数据和有权调用这些数据的函数封装在一起,组成一种称为“类(class)”的数据结构.也就是说,一个类是由一批数据以及对其操作的函数组成的。
类定义结束后要加分号对数据的声明既可以放在函数之外(其作用范围是全局的),也可以放在函数内(其作用范围是局部的,只在本函数内有效)。
用“//”作注释时,有效范围只有一行,即本行有效,不能跨行。
而用“/*……*/”作注释时有效范围为多行。
只要在开始处有一个“/*”,在最后一行结束处有一个“*/”即可。
对char赋值时,用单引号,对char型数组赋值时,用双引号。
cout<<&student1; //输出student1的首地址cout<<&student1.age; //输出student1.age的地址结构体变量的地址主要用作函数参数,将结构体变量的地址传递给形参。
u8 是unsigned charu16 是unsigned shortu32 是unsigned intu8 * 就表示指向unsigned char(无符号字符类型)的指针,属于指针类型。
如果指定为signed,则数值以补码形式存放,存储单元中的最高位(bit)用来表示数值的符号。
如果指定为unsigned,则数值没有符号,全部二进制位都用来表示数值本身。
内联函数有些类似于宏。
内联函数的代码会被直接嵌入在它被调用的地方2,调用几次就嵌入几次,没有使用call指令。
这样省去了函数调用时的一些额外开销,比如保存和恢复函数返回地址等,可以加快速度。
不过调用次数多的话,会使可执行文件变大,这样会降低速度。
相比起宏来说,内核开发者一般更喜欢使用内联函数。
因为内联函数没有长度限制,格式限制。
编译器还可以检查函数调用方式,以防止其被误用。
static inline的内联函数,一般情况下不会产生函数本身的代码,而是全部被嵌入在被调用的地方。
如果不加static,则表示该函数有可能会被其他编译单元所调用,所以一定会产生函数本身的代码。
所以加了static,一般可令可执行文件变小。
内核里一般见不到只用inline的情况,而都是使用static inline。
既然字符数据是以ASCII码存储的,它的存储形式就与整数的存储形式类似。
这样,在C++中字符型数据和整型数据之间就可以通用。
一个字符数据可以赋给一个整型变量,反之,一个整型数据也可以赋给一个字符变量。
也可以对字符数据进行算术运算,此时相当于对它们的ASCII 码进行算术运算。
用双撇号括起来的部分就是字符串常量,如"abc","Hello!","a+b","Li ping"都是字符串常量。
如果在一个字符串中最后一个字符为"\",则表示它是续行符,下一行的字符是该字符串的一部分,且在两行字符串间无空格。
C语言要求变量的定义应该放在所有的执行语句之前,而C++则放松了限制,只要求在第一次使用该变量之前进行定义即可对多个变量赋予同一初值,必须分别指定,不能写成float a=b=c=4.5;而应写成float a=4.5, b=4.5, c=4.5;需要说明的是在强制类型转换时,得到一个所需类型的中间变量,但原来变量的类型未发生变化。
将一个int、short或long型数据赋给一个char型变量,只将其低8位原封不动地送到char型变量(发生截断)。
因为char型变量只占有一个字节。
逗号表达式的求解过程是:先求解表达式1,再求解表达式2。
整个逗号表达式的值是表达式2的值。
不能用cin语句把空格字符和回车换行符作为字符输入给字符变量,它们将被跳过。
如果想将空格字符或回车换行符(或任何其他键盘上的字符)输入给字符变量,可以使用getchar函数。
putchar函数的作用是向终端输出一个字符putchar('\101'); (输出字符'A',八进制的101是'A'的ASCII码)使用cin同时一行输入多个变量时,变量类型必须相同。
C语言没有提供逻辑型数据,关系表达式的值(真或假)分别用数值1和0代表。
C++增加了逻辑型数据。
逻辑型常量只有两个,即false(假)和true(真)。
do-while语句的特点是先执行循环体,然后判断循环条件是否成立。
continue语句的一般格式为:continue;其作用为结束本次循环,即跳过循环体中下面尚未执行的语句,接着进行下一次是否执行循环的判定。
C++要求在定义函数时必须指定函数的类型其实,在函数声明中也可以不写形参名,而只写形参的类型,如float add(float, float);归纳起来,只有那些规模较小而又被频繁调用的简单函数,才适合于声明为inline函数。
C++允许用同一函数名定义多个函数,这些函数的参数个数和参数类型不同。
这就是函数的重载(function overloading)。
即对一个函数名重新赋予它新的含义,使一个函数名可以多用。
实参与形参的结合是从左至右顺序进行的。
因此指定默认值的参数必须放在形参表列中的最右端,否则出错。
例如:void f1(float a, int b=0, int c, char d=′a′);//不正确void f2(float a, int c, int b=0, char d=′a′);//正确主函数main中定义的变量(m, n)也只在主函数中有效,不会因为在主函数中定义而在整个文件或程序中有效。
主函数也不能使用其他函数中定义的变量。
如果在同一个源文件中,全局变量与局部变量同名,则在局部变量的作用范围内,全局变量被屏蔽,即它不起作用。
数据分别存放在静态存储区和动态存储区中。
全局变量全部存放在静态存储区中,在程序开始执行时给全局变量分配存储单元,程序执行完毕就释放这些空间。
在程序执行过程中它们占据固定的存储单元,而不是动态地进行分配和释放。
在动态存储区中存放以下数据:∙函数形式参数。
在调用函数时给形参分配存储空间。
∙函数中的自动变量(未加static声明的局部变量,详见后面的介绍)。
∙函数调用时的现场保护和返回地址等。
对以上这些数据,在函数调用开始时分配动态存储空间,函数结束时释放这些空间。
关键字auto可以省略,如果不写auto,则系统把它默认为自动存储类别,它属于动态存储方式。
有时希望函数中的局部变量的值在函数调用结束后不消失而保留原值,即其占用的存储单元不释放,在下一次该函数调用时,该变量保留上一次函数调用结束时的值。
这时就应该指定该局部变量为静态局部变量(static local variable)。
为提高执行效率,C++允许将局部变量的值放在CPU中的寄存器中,需要用时直接从寄存器取出参加运算,不必再到内存中去存取。
这种变量叫做寄存器变量,用关键字register作声明。
有时在程序设计中希望某些外部变量只限于被本文件引用,而不能被其他文件引用。
这时可以在定义外部变量时加一个static声明。
Extern用于声明一个已经定义的外部变量。
说明:extern只能用来声明已定义的外部变量,而不能用于变量的定义。
只要看到extern,就可以判定这是变量声明,而不是定义变量的语句。
把建立存储空间的声明称为定义,而把不需要建立存储空间的声明称为声明∙对局部变量用static声明,使该变量在本函数调用结束后不释放,整个程序执行期间始终存在,使其存储期为程序的全过程。
∙全局变量用static声明,则该变量的作用域只限于本文件模块(即被声明的文件中)。
在定义函数时,如果在函数首部的最左端冠以关键字extern,则表示此函数是外部函数,可供其他文件调用。
如函数首部可以写为:extern int fun (int a, int b);这样,函数fun就可以为其他文件调用。
如果在定义函数时省略extern,则默认为外部函数。
在#include命令中,文件名除了可以用尖括号括起来以外,还可以用双撇号括起来。
#include 命令的一般形式为:#include <文件名>或#include ″文件名″如:#include <iostream>或#include ″iostream″都是合法的。
二者的区别是:用尖括号时,系统到系统目录中寻找要包含的文件,如果找不到,编译系统就给出出错信息。
数组定义中数组元素的个数必须是常量,可以不定义数组大小,通过赋值直接自动确定数组大小。
多维数组元素在内存中的排列顺序:第一维的下标变化最慢,最右边的下标变化最快。
例如,上述三维数组的元素排列顺序为:a[0][0][0]→a[0][0][1]→a[0][0][2]→a[0][0][3]→a[0][1][0]→a[0][1][1]→a[0][1][2]→a[0][1][3]→a[0][ 2][0]→a[0][2][1]→a[0][2][2]→a[0][2][3]→a[1][0][0]→a[1][0][1]→a[1][0][2]→a[1][0][3]→a[1][1][0]→a[1][1][1]→a[1][1][2]→a[1][1][3]→a[1][2][0]→a[1][2][1]→a[1][2][2]→a[1][2][3]数组名也可以作实参和形参,传递的是数组的起始地址。
区别空字符和空格字符。
对一个字符串常量,系统会自动在所有字符的后面加一个′\0′作为结束符。
例如字符串″I am happy″共有10个字符,但在内存中它共占11个字节,最后一个字节′\0′是由系统自动加上的。
strlen是string length(字符串长度)的缩写。
它是测试字符串长度的函数。
其函数的值为字符串中的实际长度,不包括′\0′在内。
应当注意:要使用string类的功能时,必须在本文件的开头将C++标准库中的string头文件包含进来,即应加上#include <string>一个变量的地址称为该变量的指针。
如果有一个变量是专门用来存放另一变量地址(即指针)的,则它称为指针变量。
指针变量的值(即指针变量中存放的值)是地址(即指针)。
在C++中用“*”符号表示指向,例如,i_pointer是一个指针变量,而*i_pointer表示i_pointer所指向的变量float *pointer_3; // pointer_3是指向单精度型数据的指针变量char *pointer_4; // pointer_4是指向字符型数据的指针变量请注意:指针变量名是pointer_3和pointer_4,而不是*pointer_3和*pointer_4,即“*”不是指针变量名的一部分,在定义变量时在变量名前加一个“*”表示该变量是指针变量。