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

肥乡专业做网站wordpress还原明文密码

肥乡专业做网站,wordpress还原明文密码,项目经理资格证,湛江企业模板建站目录 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.1.1 关于冒泡排序函数的错误设计 4.1.2 关于冒泡排序函数的正确设计 4.2 数组名是什么? 对于二维数组的数组名 我们原来要存放一个整数, 就会: int a 1; int b 2; int c 3; 那么如果要存放1~10, 或者要存放1~100呢? 如果创建10或100个变量就不方便了, 于是就有了数组的概念. 什么是数组? 数组是一组相同类型元素的集合. 那么C语言的数组形式是什么呢, 我们一起来看. 1. 一维数组的创建和初始化 1.1 数组的创建 数组的创建方式: type_t arr_name [const_n]; // type_t 是数组的元素类型 // arr_name 是数组的数组名 // const_n 是一个常量表达式, 用来指定数组的大小 数组创建的实例: int arr[10]; char ch[5]; double data1[20]; double data2[155]; 注: 数组创建在C99标准之前[]中要给一个常量或者常量表达式才可以不能使用变量。在C99之后数组的大小可以是变量这是为了支持变长数组。 //下面的代码只能在支持C99标准的编译器上编译 int n 10; scanf(%d, n); int arr2[n];//这种数组是不能初始化 1.2 数组的初始化 数组的初始化是指在创建数组的同时给数组的内容一些合理初始值(初始化). 数组在创建的时候如果想不指定数组的确定的大小就得初始化。数组的元素个数根据初始化的内容来确定。 //不完全初始化剩余的元素默认初始化为0 int arr[10] { 1,2,3 }; int arr1[10] { 1,2,3,4,5,6,7,8,9,0 }; int arr2[] { 1,2,3 }; 但是对于下面的代码要区分内存中如何分配。 char ch1[10] { a, b, c }; //a b c 0 0 0 0 0 0 0 char ch2[10] abc; //a b c \0 0 0 0 0 0 0 char ch3[] { a, b, c }; char ch4[] abc; 1.3 一维数组的使用 对于数组的使用我们之前介绍了一个操作符: []下标引用操作符。它其实就数组访问的操作符. int arr[] { 1,2,3,4,5,6,7,8,9,10 }; // 0 1 9 当我们去访问上面这个数组的时候, 需要知道它在内存中的情况. 这段代码对应的是在内存中的栈区找了一块连续的空间, 在里面放了1~10. 那么我们可以通过下标引用操作符下标编号来访问数组中的元素. printf(%d\n, arr[4]); 如果要打印数组的每个元素: int main() {int arr[] { 1,2,3,4,5,6,7,8,9,10 };int i 0;int sz sizeof(arr) / sizeof(arr[0]);//顺序打印for (i 0; i sz; i){printf(%d , arr[i]);}//逆序打印for (i sz - 1; i 0; i--){printf(%d , arr[i]);}return 0; } 总结: 1. 数组是使用下标来访问的下标是从0开始 2. 数组的大小可以通过计算得到。 1.4 一维数组在内存中的存储 在上面的代码中加入: for (i 0; i sz; i){printf(arr[%d] %p\n, i, arr[i]);} 可以看到数组的,每个元素的地址: 观察输出的结果可以知道随着数组下标的增长元素的地址也在有规律的递增. 由此我们得出: 数组在内存中是连续存放的. 那么我们同样也是可以通过调试在内存窗口中看到数组arr在内存中的分布情况. 2. 二维数组的创建和初始化 二维数组相较于一维数组能够存放更多的数据. 它存在的原因就是因为相同的数据是可能会出现很多组. 像这种多组整数需要存储的话就可以考虑二维数组. 2.1 二维数组的创建 int arr[3][4]; // 第一个[]表示行, 第二个[]表示列. 3行4列. char arr[3][5]; double arr[2][4]; 可以看到在数组名后有两个 [], 对于第一行它表示的是三行四列的元素, 就像一个表格一样. 我们知道一维数组是一行, 而二维数组是有多行. 其实这就是一个概念. 比如说要存放下面这几组数据: 1 2 3 4 2 3 4 5 3 4 5 6 那么我们就可以创建如上文第一行代码的那样一个数组. 2.2 二维数组的初始化 int arr1[3][4] {1,2,3,4,2,3,4,5,3,4,5,6}; int arr2[3][4] { {1,2}, {3, 4}, {5, 6}}; int arr3[][4] { 1,2,3,4,5,6};//二维数组如果有初始化行可以省略列不能省略 可以看到, arr1第一行为1234, 第二行为2345, 第三行为3456. 因为我们前面已经限定了一行能放四个元素, 所以当第一行放了四个元素之后紧接着后面的初始化内容又找了四个给第二行, 再找四个给到第三行. 所以能看到如上图所示的现象. 那么如果初始化的数字不够数的时候, 会在后面初始化成0, 也如上图arr2和arr3所示. 2.3 二维数组的使用 二维数组的使用也是通过下标的方式. #include stdio.hint main() {int arr[3][4] { 1,2,3,4,2,3,4,5,3,4,5,6 };int i 0;for (i 0; i 3; i){int j 0;for (j 0; j 4; j){printf(%d , arr[i][j]);}printf(\n);}return 0; } 运行结果: 2.4 二维数组在内存中的存储 前面在我们假想中的二维数组是多行多列的一个存在, 但是实际上在内存中并不是使用行列这种样子的存储方式, 而是连续的存储. 我们来进行验证, 打印二维数组每个元素的地址: #include stdio.hint main() {int arr[3][4] { 1,2,3,4,2,3,4,5,3,4,5,6 };int i 0;for (i 0; i 3; i){int j 0;for (j 0; j 4; j){printf(arr[%d][%d] %p\n, i, j, arr[i][j]);}}return 0; } 输出结果: 通过地址的变化可以观察出: 二维数组在内存中也是连续存放的. 于是, 我们可以进一步这样理解二维数组. int arr[3][4]; 理解为从第一个元素开始向后的连续12个空间, 看成是一个连续的一维数组, 有12个元素. 其实最终, 该代码与 int arr2[12]; 在内存中的布局是一样的. 可以把二维数组理解为: 一维数组的数组. 3. 数组越界 数组的下标是有范围限制的。 数组的下规定是从0开始的如果数组有n个元素最后一个元素的下标就是n-1。 所以数组的下标如果小于0或者大于n-1就是数组越界访问了超出了数组合法空间的访问。 C语言本身是不做数组下标的越界检查编译器也不一定报错但是编译器不报错并不意味着程序就是正确的。 所以程序员写代码时最好自己做越界的检查。 二维数组的行和列也可能存在越界。 4. 数组作为函数参数 往往我们在写代码的时候会将数组作为参数传个函数比如: 我要实现一个冒泡排序函数将一个整形数组排序. 冒泡排序的核心思想: 两个相邻的元素进行比较 代码思路: 4.1 冒泡排序函数的设计 4.1.1 关于冒泡排序函数的错误设计 int main() {//数组//把数组的数据排成升序int arr[] { 9,8,7,6,5,4,3,2,1,0 };//0 1 2 3 4 5 6 7 8 9int sz sizeof(arr) / sizeof(arr[0]);//冒泡排序的算法对数组进行排序bubble_sort(arr);int i 0;for (i 0; i sz; i){printf(%d , arr[i]);}return 0; } void bubble_sort(int arr[]) {//趟数int sz sizeof(arr) / sizeof(arr[0]);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;}}} } 执行上述代码之后, 会出问题, 并不能正确的将数据进行排序. 我们进行调试: 在调试到bubble_sort()中发现sz变成了1, 但是我们期望是10, 此时往下1-10, 并没有进行任何的对数据排序就退出了这个函数, 所以当整个程序执行完会发现并没有将数据进行排序就输出. 这是函数程序的编写中非常常见的错误. 4.1.2 关于冒泡排序函数的正确设计 //形参是数组的形式 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[] { 9,8,7,6,5,4,3,2,1,0 };//0 1 2 3 4 5 6 7 8 9int sz sizeof(arr) / sizeof(arr[0]);//冒泡排序的算法对数组进行排序bubble_sort(arr, sz);int i 0;for (i 0; i sz; i){printf(%d , arr[i]);}return 0; } //形参是指针的形式 void bubble_sort(int* arr,int sz) {//趟数int i 0;for (i 0; i sz-1; i){//一趟冒泡排序int j 0;for (j0; jsz-1-i; j){if (arr[j] arr[j 1]){//交换int tmp arr[j];arr[j] arr[j 1];arr[j 1] tmp;}}} } 4.2 数组名是什么? 前面提到, 数组名是数组首元素的地址, 这个说法虽然对, 但是其实并不完全对, 有两个例外. 1. sizeof(数组名)这里的数组名表示整个数组计算的是整个数组的大小单位是字节 2. 数组名这里的数组名表示整个数组取出的是整个数组的地址 int main() {int arr[10] {0};printf(%p\n, arr);//arr就是首元素的地址printf(%p\n, arr1);printf(----------------------\n);printf(%p\n, arr[0]);//首元素的地址printf(%p\n, arr[0]1);printf(----------------------\n);printf(%p\n, arr);//数组 的地址printf(%p\n, arr1);//int n sizeof(arr);//40//printf(%d\n, n);return 0; } 执行结果: 对于二维数组的数组名 #include stdio.hint main() {int arr[3][4] {0};printf(%d\n, sizeof(arr) / sizeof(arr[0]));//计算行printf(%d\n, sizeof(arr[0]) / sizeof(arr[0][0]));//计算列int sz sizeof(arr);printf(%d\n, sz); //48printf(%p\n, arr);//二维数组的数组名也表示数组首元素的地址(第一行的地址)printf(%p\n, arr1);//第二行return 0; }
http://www.dnsts.com.cn/news/157037.html

相关文章:

  • 网站必备功能鄙视wordpress
  • 做网站网址北京商场招商信息
  • 温泉酒店网站建设方案怎么用html5做自适应网站
  • 让自己的电脑做网站的服务器汕头网站设计
  • 免费手机版网站建设百度平台订单查询
  • 网站demo制作工具增加网站产品
  • 做服装招聘的网站有哪些内容cpa广告联盟网站建设
  • 专门型网站厦门手机网站建设是什么意思
  • 广东建设银行网站it培训网站
  • 网站优化seo中山教育平台网站建设
  • 拉趣网站是谁做的金华网站建设方案咨询
  • 做网站设计师能10年赚100万吗中国能源建设招标网站
  • 咸阳做网站xymokj有后台的网站怎么做
  • 美食网站建设方案做网站_没内容
  • 做网站f12的用处镇江网站建设推广
  • 在施工过程中某施工企业的安全seo关键词优化技巧
  • 军事网站 模板电脑上如何进入wordpress
  • 免费ai写作网站泰安人才网最新招聘
  • 购物网站seo合肥网页制作设计
  • 此网站服务器不在国内维护手机排行榜
  • 成视频app下无限看ios7网站seo
  • 做淘宝店铺标志的网站鲁中网站
  • 南宁网站建设_seo优化服务公司做体育类网站素材
  • 智慧政务门户网站建设方案浏览器大全下载
  • 米拓网站建设-app定制开发长春优化所
  • 网站的总规划书页面布局标准格式
  • 北京网站建设公司内江上海动易 网站
  • 开创云网站建设网站内容 内链
  • 济南手机网站开发公司网站建设 国风网络
  • 网站开发技术与应用试验报告4vps 安装 wordpress