当前位置: 首页 > wzjs >正文

怀远网站建设哪家好网站如何绑定虚拟主机

怀远网站建设哪家好,网站如何绑定虚拟主机,网站建设合同要缴纳印花税吗,怎样把网站做的更吸引目录 1. 数组名 2. 指针访问数组 3. 一维数组的传参(本质) 4. 冒泡排序 5. 二级指针 6. 指针数组(指针的数组) 7. 指针数组模拟二维数组 1. 数组名 在之前的代码中我们使用指针访问过数组的内容。 int arr[10] {1,2,3,4…

目录

1. 数组名

2. 指针访问数组

3. 一维数组的传参(本质)

4. 冒泡排序

5. 二级指针

6. 指针数组(指针的数组)

7. 指针数组模拟二维数组


1. 数组名

在之前的代码中我们使用指针访问过数组的内容。

int arr[10] = {1,2,3,4,5,6,7,8,9,10};
int *p = &arr[0];//通过&爱如如[0]来拿到数组的第一个元素的地址

数组名其实本来就是地址,而且是数组首元素的地址。

#include <stdio.h>
int main()
{int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };printf("&arr[0] = %p\n", &arr[0]);printf("arr = %p\n", arr);return 0;
}

但是如果是下面的代码,就不能这么理解。

总结: 数组名一般情况下就是首元素(第一个元素)的地址,但是有两个例外:

1.  sizeof(数组名),sizeof中单独放数组名,这里的数组名表示的是整个数组,计算的是整个数组的大小,单位为字节;

2. &数组名,这里的数组名表示的是整个数组,取出的是整个数组的地址(整个数组的地址和数组⾸元素的地址是有区别的)

知道这些后我们来看一下下面的代码,来充分理解一下。

 &arr[0] 和 arr 都是 ⾸元素的地址,+1就是跳过⼀个元素

&arr是数组的地址,+1 操作是跳过整个数组的。

2. 指针访问数组

因为数组名在内存中是连续存放的,数组名就是首元素的地址(方便找到起始位置),这样可以使用指针来访问数组

#include <stdio.h>
int main()
{int arr[10] = { 0 };int i = 0;int sz = sizeof(arr) / sizeof(arr[0]);//输⼊int* p = arr;//指针p指向arr数组的首元素的地址for (i = 0; i < sz; i++){scanf("%d", p + i);//scanf("%d", &arr[i]);//也可以这样写//scnaf("%d", *(arr+i));}//输出for (i = 0; i < sz; i++){printf("%d ", *(p + i));//printf("%d", arr[i]);//printf("%d", *(arr+i));}return 0;
}
//arr[i]==*(arr+i)  p[i]==*(p+i)

注:数组元素的访问在编译器处理的时候,也是转换成⾸元素的地址+偏移量求出元素的地址,然后解引⽤来访问的。

3. 一维数组的传参(本质)

我们之前都是在函数外部计算数组的元素个数,那我们可以把函数传给⼀个函 数后,函数内部求数组的元素个数吗?

在数组传参的时候,传递的是数组名,也就是说本质上数组传参本质上传递的是数组首元素的地址。

总结:⼀维数组传参,形参的部分可以写成数组的形式,也可以写成指针的形式。

4. 冒泡排序

冒泡排序的核心思想就是:两两相邻的元素进行比较

#include <stdio.h>
void bubble_sort(int arr[], int sz)//参数接收数组元素个数
{int i = 0;for (i = 0; i < sz - 1; i++){int j = 0;for (j = 0; j < sz - i - 1; j++){if (arr[j] > arr[j + 1]){int tmp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = tmp;}}}
}
int main()
{int arr[] = { 3,1,7,5,8,9,0,2,4,6 };int sz = sizeof(arr) / sizeof(arr[0]);bubble_sort(arr, sz);for (int i = 0; i < sz; i++){printf("%d ", arr[i]);}return 0;
}

5. 二级指针

指针变量也是变量,是变量就有地址,那指针变量的地址存放在二级指针中。

 对二级指针的运算:

*ppa 通过对ppa中的地址进⾏解引⽤,这样找到的是 pa , *ppa 其实访问的就是 pa

**ppa 先通过 *ppa 找到 pa ,然后对 pa 进⾏解引⽤操作: *pa ,那找到的是 a

6. 指针数组(指针的数组)

这是整数数组和字符数组:

 我们可以知道指针数组就是每个元素都是用来存放指针(地址)的。

7. 指针数组模拟二维数组

#include <stdio.h>
int main()
{int arr1[] = { 1,2,3,4,5 };int arr2[] = { 2,3,4,5,6 };int arr3[] = { 3,4,5,6,7 };//数组名是数组⾸元素的地址,类型是int*的,就可以存放在parr数组中int* parr[3] = { arr1, arr2, arr3 };int i = 0;int j = 0;for (i = 0; i < 3; i++){for (j = 0; j < 5; j++){printf("%d ", parr[i][j]);}printf("\n");}return 0;
}

 parr[i]是访问parr数组的元素,parr[i]找到的数组元素指向了整型⼀维数组,parr[i][j]就是整型⼀维数组中的元素,但是要注意模拟始终只是模拟,实际上并完全是二维数组,因为每一行都不是连续的。

http://www.dtcms.com/wzjs/537532.html

相关文章:

  • 做网站的出路抖音小程序游戏怎么免广告拿奖励
  • 优质的武进网站建设公司网站建设任务书
  • wordpress网站如何播放视频百度快照优化排名推广怎么做
  • 一个服务器能放多少网站网站流量
  • 中英文网站怎么实现elo机制
  • 网站的建设成本的账务处理海洋生态文明建设的网站名
  • 微信公众号怎么做链接网站全网搜索指数
  • 本机做网站如何访问网站可以做外部链接吗
  • 建设淘宝客网站多少钱长春vi设计公司
  • 学做网站初入门教程色粉引流推广平台
  • 建设微商城网站wordpress视频主题模板下载
  • 博物馆网站建设目的深圳建网站服务商
  • 做付费网站网站开发外键
  • 开题报告网站开发方法网页设计教程孟宪宁
  • 模板建网站怎么做seo西昌市做网站的公司
  • 仿站WordPress短期职业技能培训班
  • 网站建设企业有哪些微信服务市场
  • 网站建设与制作罗湖网站制作公司
  • 关于动物自己做的网站福州网站网页设计
  • 会HTML怎么做网站新站优化案例
  • 网站漂浮广告代码wordpress 公式编辑器
  • 网站建设与管理学什么阿里云域名查询和注册
  • 东城精锐传媒专注于各类网站建设国外网站做推广
  • 注册一个免费的网站可发外链的高权重网站
  • 网站编辑是什么做网站需要懂那些软件
  • 广西住房与城乡建设部网站中国的平面设计网站
  • 可以免费申请试用的网站静态网站做301重定向
  • 网站名称需要用注册吗wordpress主题jquery
  • 江门网站建设价格专业做家政网站
  • 西宁企业网站建设如何登入 WORDPRESS 后台