IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 数据结构00 C/C++复习 -> 正文阅读

[C++知识库]数据结构00 C/C++复习

数据结构00 C/C++复习

00.1 C语言的动态分配函数(<stdlib.h>)

malloc(m)  //开辟m字节长度的地址并返回这段空间的首地址
sizeof(x)  //计算变量x的长度
free(p)  //释放p指针所指变量的存储空间,即彻底删除一个变量

00.2 C++的动态存储分配

int *p1=new int;
int *p2=new int(10);
/* new 类型名T(初值列表)

功能:
申请用于存放T类型对象的内存空间,并依初值列表赋以初值。
结果值:
成功值:T 类型指针,指向新分配的内存
失败:0(NULL)
*/
delete p1;
/*
delete 指针P
功能:
释放P指针所指向的内存。P必须是new操作的返回值。
*/

00.3 C++中的参数传递

函数调用时传送给形参表的实参必须与形参在类型、个数、顺序上保持一致。
参数传递有两种方式。

00.3.1 传值方式:(参数为整型、实型、字符型等)

把实参的值传送给函数局部工作区相应的副本中,函数使用这个副本执行必要的功能。函数修改的时副本的值,实参的值不变。

#include<iostream>
void swap(float m,float n)  //交换m,n的值
{
    float temp;
    temp=m;
    m=n;
    n=temp;
}
void main()
{
    using namespace std;
    float a,b;
    cin>>a>>b;
    swap(a,b);  //由于传入swap中的ab只有值所以主函数的ab值不变。
    cout<<a<<endl<<b<<endl;
}

00.3.2传地址方式:参数为指针变量,参数为引用类型,参数为数组名。

形参变化影响实参。

00.3.2.1 传地址方式——参数为指针变量

#include<iostream>
void swap(float *m,float *n)  //交换m,n的值
{
    float temp;
    temp=*m;
    *m=*n;
    *n=temp;
}
void main()
{
    using namespace std;
    float a,b,*p1,*p2;
    cin>>a>>b;
    p1=&a;
    p2=&b;
    swap(p1,p2);  //由于传入swap中的p1,p2为a,b的储存地址,所以形参变化会影响实参。
    cout<<a<<endl<<b<<endl;
}

00.3.2.2 传地址方式——引用类型作参数

引用可以简单地认为它给一个对象提供一个替代的名字。

#include<iostream>
void main()
{
    using namespace std;
    int i=5;
    int &j=i;
    i=7;
    cout<<”I=”<<i<<”j”<<j; //输出为i=7j=7
}
PS:C++中 &的用法
  1. & 二进制的位与运算。例如 二进制数字 100 & 111 = 100;
  2. & 可以表示取地址。
    例如
    void main()
{
    int a = 20;
    int *p = &a;
}

以上均与C语言中的用法相同。
3. &在C++中还可以作为引用
1)引用就是为某一变量设置别名,对引用的操作等效于对变量本身操作;
2)引用的方式:数据类型 &引用名 = 目标变量

int a = 20;
int &b = a; //b 为对 a 的引用

注:
引用不会定义新的变量,系统不会开辟新的内存空间给b,即 a 跟 b 指向的相同的地址。
引用常用于函数的参数来使用,在函数的内部对引用进行操作,就等效于对原变量的操作。

代码示例:

#include<iostream>
void swap(float &m,float &n)
{
    float temp;
    temp=m;
    m=n;
    n=temp;
}
void main()
{
    using namespace std;
    float a,b;
    cin>>a>>b;
    swap(a,b);
    cout<<a<<endl<<b<<endl;
}
引用类型做形参的三种说明
1. 传递引用函数给与传递指针的效果是一样的,形参变化实参也发生变化。
2. 引用类型作形参,在内存中并没有产生实参的副本,它直接对实参操作;而一般变量做参数,形参与实参就占用不同的储存单元,所以形参变量的值是实参变量的副本。因此,当参数传递的数据量较大时,用引用比用一般变量传递参数的时间和空间效率都好。
3. 指针虽然也能达到与使用引用的效果,但在被调函数中需要重复使用“*指针变量名”的形式进行运算,这很容易产生错误且程序的阅读性较差;另一方面,在主调函数的调用点处,必须用变量的地址作为实参。

00.3.2.3 传地址方式——数组名做参数

传递的是数组的首地址
对形参数组所做的任何改变都将反映到是参数组中。

#include<iostream>
void sub(char);
void main(void )
{
    using namespace std;
    char a[10]=“hello”;
    sub(a);
    cout<<a<<endl;
}
void sub(char b[ ])
{
    b[ ]=“world”;
}

代码示例:
用数组作函数的参数,求10个整数的最大数

#iniclude<iostream>
#define N 10
int max(int a[]);
void main ( )
{
    using namespace std;
    int a[10];
    int i,m;
    for(i=0;i<N;i++)
        cin>>a[i];
    m=max(a);
    cout<<"the max number is:"<<m;
}
int max(int b[])  //函数功能找到数组内的最大数。
{
    using namespace std;
    int i,n;
    n=b[0];
    for(i=1;i<N;i++)
        if(n<b[i]) n=b[i];
            return n;
}

00.4 结构体

C允许用户按自己的需要将不同的基本类型构造成一种特
殊类型,即结构。

在C中

//C中声明结构体要使用typedef
typedef struct book{
    char no[15];   
    char name[50]; 
    float price;   
}Book; 
Book b[10];  //

在数据结构中与平常声明结构体不同的是加入了typedef

PS:typedef

typedef是一个高级数据特性,利用typedef可以为某一类型自定义名称。这方面与#define类似,但是两者由三处不同:

1. 与#define不同,typedef创建的符号名只受限于类型,不能用于值。
2. typedef由编译器解释,不是预处理器。
3. 在其受限范围内,typedef比#define更灵活。

通过结构、联合和typedef,C提供了有效处理数据的工具和处理可移植数据的工具。
f可以为某一类型自定义名称。这方面与#define类似,但是两者由三处不同:

1. 与#define不同,typedef创建的符号名只受限于类型,不能用于值。
2. typedef由编译器解释,不是预处理器。
3. 在其受限范围内,typedef比#define更灵活。

通过结构、联合和typedef,C提供了有效处理数据的工具和处理可移植数据的工具。

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-17 21:52:22  更:2022-03-17 21:53:53 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 16:24:27-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码