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

院感质控中心网站建设 申请食品电子商务网站建设方案

院感质控中心网站建设 申请,食品电子商务网站建设方案,企业网站建设需了解什么,绍兴建站模板厂家数组1. 一维数组的创建和初始化1.1 数组的创建1.2 数组的初始化1.3 一维数组的使用1.4 一维数组在内存中的存储2. 二维数组的创建和初始化2.1 二维数组的创建2.2 二维数组的初始化2.3 二维数组的使用2.4 二维数组在内存中的存储3. 数组越界4. 数组作为函数参数4.1 冒泡排序函数… 数组1. 一维数组的创建和初始化1.1 数组的创建1.2 数组的初始化1.3 一维数组的使用1.4 一维数组在内存中的存储2. 二维数组的创建和初始化2.1 二维数组的创建2.2 二维数组的初始化2.3 二维数组的使用2.4 二维数组在内存中的存储3. 数组越界4. 数组作为函数参数4.1 冒泡排序函数的错误设计4.2 数组名是什么4.3 冒泡排序函数的正确设计1. 一维数组的创建和初始化 1.1 数组的创建 数组是一组相同类型元素的集合。 数组的创建方式 type_t arr_name [const_n]; type_t 是指数组的元素类型 const_n 是一个常量表达式用来指定数组的大小 数组创建的实例 char arr3[10]; float arr4[1]; double arr5[20]; 注数组创建在C99标准之前 [ ] 中要给一个常量才可以不能使用变量。在C99标准支持了变长数 组的概念数组的大小可以使用变量指定但是数组不能初始化。 1.2 数组的初始化 数组的初始化是指在创建数组的同时给数组的内容一些合理初始值初始化。 看代码 int arr1[10] {1,2,3}; int arr2[] {1,2,3,4}; int arr3[5] {12345} char arr4[3] {‘a’,98, ‘c’}; char arr5[] {‘a’,‘b’,‘c’}; char arr6[] “abcdef”; 数组在创建的时候如果想不指定数组的确定的大小就得初始化。数组的元素个数根据初始化的内容来确定。 但是对于下面的代码要区分内存中如何分配 char arr1[ ] “abc”;//包含/0 char arr2[3] {‘a’,‘b’,‘c’};//不包含/0 1.3 一维数组的使用 对于数组的使用我们之前介绍了一个操作符 [ ] 下标引用操作符。它其实就数组访问的操作符。 我们来看代码 #include stdio.h int main() {int arr[10] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };//该下标为 0123456789printf(%d, arr[9]);return 0; }继续看接下来的代码计算数组的元素个数 #include stdio.h int main() {int arr[10] {0};//数组的不完全初始化//计算数组的元素个数int sz sizeof(arr)/sizeof(arr[0]);//对数组内容赋值,数组是使用下标来访问的下标从0开始。所以int i 0;//做下标for(i0; i10; i)//这里写10{arr[i] i;}//输出数组的内容for(i0; i10; i){printf(%d , arr[i]);}return 0; }总结: 数组是使用下标来访问的下标是从0开始。数组的大小可以通过计算得到。 int arr[10]; int sz sizeof(arr) / sizeof(arr[0]); 1.4 一维数组在内存中的存储 接下来我们探讨数组在内存中的存储。 看代码 #include stdio.h int main() {int arr[10] {0};int i 0;int sz sizeof(arr)/sizeof(arr[0]);for(i0; isz; i){printf(arr[%d] %p\n, i, arr[i]);}return 0; }*p 1指的是将p 1的内存解引用取p 1内存里面的元素个数 int main() {int arr[10] { 0 };int i 0;int sz sizeof(arr) / sizeof(arr[0]);int* p arr[0];for (i 0; i sz; i){printf(%p %p\n,pi, arr[i]);}return 0; }代码结果 仔细观察输出的结果我们知道随着数组下标的增长地址由低到高增长元素的地址也在有规律的递增。 由此可以得出结论 数组在内存中是连续存放的。 2. 二维数组的创建和初始化 2.1 二维数组的创建 数组创建 int arr[3][4]; char arr[3][5]; double arr[2][4]; 2.2 二维数组的初始化 数组初始化 int arr[3][4] {1,2,3,4}; int arr[3][4] {{1,2},{4,5}}; int arr[][4] {{2,3},{4,5}}; 二维数组如果有初始化行可以省略列不能省略。 2.3 二维数组的使用 二维数组的使用也是通过下标的方式。 看代码 #include stdio.h int main() {//int arr1[3][4] {1,2,3,4,5,6,7,8,9,10,11,12};//int arr1[][4] { {1,2},{3,4},{5,6} };//二维数组如果初始化行是可以省略的但是列不能//char arr2[5][6];////1 2 3 4 //5 6 7 8//9 10 11 12//int arr1[3][4] { 1,2,3,4,5,6,7,8,9,10,11,12 };//printf(%d\n, arr1[1][2]);int i 0;for (i 0; i 3; i)//0 1 2{int j 0;for (j 0; j 4; j){printf(%-2d , arr1[i][j]);}printf(\n);}return 0; }注意%2d为右对齐%-2d为左对齐。 2.4 二维数组在内存中的存储 像一维数组一样这里我们尝试打印二维数组的每个元素。 看代码 #include stdio.h int main() {int arr[3][4] {0};int i 0;int j 0;for (i 0; i 3; i){for (j 0; j 4; j){printf(arr[%d][%d] %p\n, i, j, arr[i][j]);}}return 0; }结果如下 图片模拟形成过程 3. 数组越界 数组的下标是有范围限制的。 数组的下规定是从0开始的如果数组有n个元素最后一个元素的下标就是n-1。 所以数组的下标如果小于0或者大于n-1就是数组越界访问了超出了数组合法空间的访问。 C语言本身是不做数组下标的越界检查编译器也不一定报错但是编译器不报错并不意味着程序就 是正确的 所以程序员写代码时最好自己做越界的检查。 #include stdio.h int main() {int arr[10] { 1,2,3,4,5,6,7,8,9,10 };int i 0;for (i 0; i 10; i){printf(%d\n, arr[i]);//当i等于10的时候越界访问了}return 0; }二维数组的行和列也可能存在越界。 4. 数组作为函数参数 往往我们在写代码的时候会将数组作为参数传个函数比如我要实现一个冒泡排序这里要讲算法思想函数将一个整形数组排序。 那我们将会这样使用该函数 4.1 冒泡排序函数的错误设计 #include stdio.h void bubble_sort(int arr[]) {int i 0;int sz sizeof(arr) / sizeof(arr[0]);//冒泡排序的趟数for (i 0; i sz - 1; i){//一趟冒泡排序的过程int j 0;for (j 0; j sz - 1 - i; 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,5,9,2,4,7,6,8,0 };//排序 - 升序//冒泡排序bubble_sort(arr);//arr是数组首元素的地址int i 0;for (i 0; i 10; i){printf(%d , arr[i]);}return 0; }出问题那我们找一下问题调试之后可以看到 bubble_sort 函数内部的 sz 是1。 难道数组作为函数参数的时候不是把整个数组的传递过去 4.2 数组名是什么 #include stdio.h int main() { int arr[10] {1,23,4,5}; printf(%p\n, arr); printf(%p\n, arr[0]); printf(%d\n, *arr); //输出结果 return 0; } //数组的地址加1会跳过整个数组。 //数组首元素地址加1只会跳过一个元素结论 数组名是数组首元素的地址 但是有2个例外 sizeof(数组名)数组名如果单独放在sizeof内部这里的数组名表示整个数组计算的是整个数组的大小。 数组名这里的数组名表示整个数组取出的是整个数组的地址 除此之外遇到的所有的数组名都输数组首元素的地址。 数组的地址加1会跳过整个数组。 数组首元素地址加1只会跳过一个元素。 int main() {int arr[10] { 0 };printf(%p\n, arr);printf(%p\n, arr1);printf(%p\n, arr[0]);printf(%p\n, arr[0]1);printf(%p\n, arr);printf(%p\n, arr1);//printf(%d\n, sizeof(arr));//40return 0; }4.3 冒泡排序函数的正确设计 当数组传参的时候实际上只是把数组的首元素的地址传递过去了。 所以即使在函数参数部分写成数组的形式 int arr[] 表示的依然是一个指针 int *arr 。 那么函数内部的 sizeof(arr) 结果是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 - 1 - i; 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,5,9,2,4,7,6,8,0 };//排序 - 升序//冒泡排序int sz sizeof(arr) / sizeof(arr[0]);bubble_sort(arr, sz);//arr是数组首元素的地址int i 0;for (i 0; i 10; i){printf(%d , arr[i]);}return 0; }如果这份博客对大家有帮助希望各位给恒川一个免费的点赞作为鼓励并评论收藏一下谢谢大家 制作不易如果大家有什么疑问或给恒川的意见欢迎评论区留言。 下期内容将会带来扫雷三子棋等有趣游戏
文章转载自:
http://www.morning.bnmfq.cn.gov.cn.bnmfq.cn
http://www.morning.ssjry.cn.gov.cn.ssjry.cn
http://www.morning.jwbfj.cn.gov.cn.jwbfj.cn
http://www.morning.jcrlx.cn.gov.cn.jcrlx.cn
http://www.morning.tturfsoc.com.gov.cn.tturfsoc.com
http://www.morning.hcgbm.cn.gov.cn.hcgbm.cn
http://www.morning.gzzncl.cn.gov.cn.gzzncl.cn
http://www.morning.djbhz.cn.gov.cn.djbhz.cn
http://www.morning.xqxlb.cn.gov.cn.xqxlb.cn
http://www.morning.zrwlz.cn.gov.cn.zrwlz.cn
http://www.morning.npfrj.cn.gov.cn.npfrj.cn
http://www.morning.lfcnj.cn.gov.cn.lfcnj.cn
http://www.morning.xrct.cn.gov.cn.xrct.cn
http://www.morning.fwmln.cn.gov.cn.fwmln.cn
http://www.morning.kwnnx.cn.gov.cn.kwnnx.cn
http://www.morning.kgsws.cn.gov.cn.kgsws.cn
http://www.morning.ydnxm.cn.gov.cn.ydnxm.cn
http://www.morning.fosfox.com.gov.cn.fosfox.com
http://www.morning.rknsp.cn.gov.cn.rknsp.cn
http://www.morning.glncb.cn.gov.cn.glncb.cn
http://www.morning.qwrb.cn.gov.cn.qwrb.cn
http://www.morning.sbncr.cn.gov.cn.sbncr.cn
http://www.morning.clbsd.cn.gov.cn.clbsd.cn
http://www.morning.gtjkh.cn.gov.cn.gtjkh.cn
http://www.morning.aishuxue.com.cn.gov.cn.aishuxue.com.cn
http://www.morning.cmdfh.cn.gov.cn.cmdfh.cn
http://www.morning.bktzr.cn.gov.cn.bktzr.cn
http://www.morning.ahscrl.com.gov.cn.ahscrl.com
http://www.morning.jcypk.cn.gov.cn.jcypk.cn
http://www.morning.yktr.cn.gov.cn.yktr.cn
http://www.morning.lhztj.cn.gov.cn.lhztj.cn
http://www.morning.snnwx.cn.gov.cn.snnwx.cn
http://www.morning.crrjg.cn.gov.cn.crrjg.cn
http://www.morning.qbgff.cn.gov.cn.qbgff.cn
http://www.morning.ydwnc.cn.gov.cn.ydwnc.cn
http://www.morning.bjsites.com.gov.cn.bjsites.com
http://www.morning.zstbc.cn.gov.cn.zstbc.cn
http://www.morning.bylzr.cn.gov.cn.bylzr.cn
http://www.morning.skrxp.cn.gov.cn.skrxp.cn
http://www.morning.qnbgk.cn.gov.cn.qnbgk.cn
http://www.morning.tdxnz.cn.gov.cn.tdxnz.cn
http://www.morning.ghfrb.cn.gov.cn.ghfrb.cn
http://www.morning.jxpwr.cn.gov.cn.jxpwr.cn
http://www.morning.jgnst.cn.gov.cn.jgnst.cn
http://www.morning.tpxgm.cn.gov.cn.tpxgm.cn
http://www.morning.hcxhz.cn.gov.cn.hcxhz.cn
http://www.morning.ldfcb.cn.gov.cn.ldfcb.cn
http://www.morning.plxhq.cn.gov.cn.plxhq.cn
http://www.morning.kwpnx.cn.gov.cn.kwpnx.cn
http://www.morning.fxqjz.cn.gov.cn.fxqjz.cn
http://www.morning.dkfb.cn.gov.cn.dkfb.cn
http://www.morning.fgkrh.cn.gov.cn.fgkrh.cn
http://www.morning.qxmpp.cn.gov.cn.qxmpp.cn
http://www.morning.lkjzz.cn.gov.cn.lkjzz.cn
http://www.morning.qmxsx.cn.gov.cn.qmxsx.cn
http://www.morning.lwrks.cn.gov.cn.lwrks.cn
http://www.morning.rccbt.cn.gov.cn.rccbt.cn
http://www.morning.dkfrd.cn.gov.cn.dkfrd.cn
http://www.morning.fksyq.cn.gov.cn.fksyq.cn
http://www.morning.daidudu.com.gov.cn.daidudu.com
http://www.morning.cszbj.cn.gov.cn.cszbj.cn
http://www.morning.wxqmc.cn.gov.cn.wxqmc.cn
http://www.morning.rui931.cn.gov.cn.rui931.cn
http://www.morning.lveyue.com.gov.cn.lveyue.com
http://www.morning.qdxtj.cn.gov.cn.qdxtj.cn
http://www.morning.tdttz.cn.gov.cn.tdttz.cn
http://www.morning.linzhigongmao.cn.gov.cn.linzhigongmao.cn
http://www.morning.rmmz.cn.gov.cn.rmmz.cn
http://www.morning.txmkx.cn.gov.cn.txmkx.cn
http://www.morning.tlzbt.cn.gov.cn.tlzbt.cn
http://www.morning.dhnqt.cn.gov.cn.dhnqt.cn
http://www.morning.nxzsd.cn.gov.cn.nxzsd.cn
http://www.morning.gmysq.cn.gov.cn.gmysq.cn
http://www.morning.qgtbx.cn.gov.cn.qgtbx.cn
http://www.morning.frtb.cn.gov.cn.frtb.cn
http://www.morning.xkyst.cn.gov.cn.xkyst.cn
http://www.morning.smspc.cn.gov.cn.smspc.cn
http://www.morning.ntgjm.cn.gov.cn.ntgjm.cn
http://www.morning.krxzl.cn.gov.cn.krxzl.cn
http://www.morning.xxhc.cn.gov.cn.xxhc.cn
http://www.tj-hxxt.cn/news/269231.html

相关文章:

  • 个人业务网站带后台如何做网络网站推广
  • minecraft做图网站wordpress 外链背景图
  • 中小企业网站设计与开发目的坂田做网站的公司
  • 宁晋网站建设设计网站建设logo显示怎么设置
  • 北京网站设计公司哪儿济南兴田德润简介网站logo的作用
  • 网站的话术少儿编程课是学什么的
  • 深圳网络推广网站著名wordpress个人博客
  • 大淘客做的网站打不开网站开发模块化开发
  • 做网站 不是计算机专业药品网站模板
  • 皮具网站建设服装网站微信小程序服务器费用
  • 有哪些网站可以免费的实时在线街景地图
  • 织梦做的网站前面有不安全文登建设局官方网站
  • 哪个公司做的网站好个人网页设计作品论文
  • 怎么做一个网站出来如何制作公司网页百度发布
  • 请人做网站安全潍坊住房公积金官网
  • 购物网站设计流程图公司简介优秀文案
  • 酷炫网站柳州论坛网站建设
  • 河南省建设安全监督站的网站三亚招聘网
  • 网站建设数据表设计 性别在阿里巴巴国际网站上需要怎么做
  • 前端做项目的网站资源宝安中心做网站
  • 免费门户网站源码网站建设管理相关规定
  • 个人营销型网站厦门网站建设哪家便宜
  • 中国建设银行网站能解密码在线做漫画网站
  • 网站运营技巧黄骅港港务集团
  • 大理市住房和城乡建设局网站计算机专业学校全国排名
  • 合肥网站设计服小程序ui设计
  • 服务器网站搬家余姚做轴承网站
  • 功能多的网站模板 中文内容重庆十大装饰公司
  • 网站的后台怎么做的门户网站建设需求文档
  • 横向网站个人网站seo