用几种不同的方式表示数组

#include<stdio.h>
void main()
{
	int a[]={0,1,2,3,4,5};
	int i;
	int *p;
	p=a;
	for(i=0;i<6;i++)
		printf("a[%d]=%d\t",i,a[i]);
	printf("\n");
	for(i=0;i<6;i++)
		printf("*(p+%d)=%d\t",i,*(p+i));
	printf("\n");
	for(p=a;p<a+6;p++)
		printf("*p=%d\t",*p);
	printf("\n");
	for(p=a+5,i=5;i>=0;i--)
		printf("p[-%d]=%d\t",i,p[-i]);
	/*在数组中数组名代表数组的首地址,p[i]表示的是地址为p+i的元素的值*/
	printf("\n");
	/**************************************************************/
	int b[3][4]={{1,2,3},{4,5,6}}, j;
	j=b[2][-2] + b[1][3];
	printf("%d\n",j);
	/*取某个元素时,是先通过计算这个元素的地址,再通过计算得来的地址取得该元素的。依然以二维数组为例,
	设数组a[rows][cols](即有rows行,cols列),当访问a[i][j]的时候,是先通过i,j的值计算得到要取的元素的地址,
	再在这个地址上取得该值的。计算地址的方法是: a + i*cols + j, 这里a就是数组名,它实际存放着上是这个数组的
	每一个元素的地址。可能计算得到a[2][-2]的元素地址为 a+2*4 + (-2) = a + 6 = a + 1*4 + 2 它的地址与元素a[1][2]的地址一样*/
}

用几种不同的方式表示数组

时间: 2025-01-13 09:21:15

用几种不同的方式表示数组的相关文章

jQuery自动补全插件使用,三种获取数据源方式

jQuery有很多很多的已经实现,很漂亮的插件,autocomplete就是其中之一.jQuery ui autocomplete主要支持字符串Array.JSON两种数据格式. 主要参数: Source:数据源,类型为String.Array.Function,其中String为ajax请求的服务器端地址,返回Array/JSON格式,Array即为数组,静态定义到页面中的数据,下面会有具体的  demo, Function(request,response):通过request.term获得

10.2.3.1 以函数方式使用数组

我们先来看一个 F# 的例子,这是两个F# 库处理数组的重要的高阶函数,然后,用 C# 实现相同的功能.清单 10.12 的中脚本,先用随机数初始化一个数组,然后,计算出它们的平方. 清单 10.12 处理数组的函数式方法(F# Interactive) > let rnd = new System.Random();; val rnd : System.Random > let numbers = Array.init 5 (fun _-> rnd.Next(10));;   [1]

[C#]几种Bitmap比较方式

这里选取图片,规格如下: 大小: 关键代码: using System; using System.Diagnostics; using System.Drawing; using System.Drawing.Imaging; using System.IO; using System.Runtime.InteropServices; namespace ConsoleApplication27 { class Program { static void Main(string[] args)

ArrayList和LinkedList的几种循环遍历方式及性能对比分析

主要介绍ArrayList和LinkedList这两种list的五种循环遍历方式,各种方式的性能测试对比,根据ArrayList和LinkedList的源码实现分析性能结果,总结结论.通过本文你可以了解(1)List的五种遍历方式及各自性能 (2)foreach及Iterator的实现 (3)加深对ArrayList和LinkedList实现的了解.阅读本文前希望你已经了解ArrayList顺序存储和LinkedList链式的结构,本文不对此进行介绍. 相关:HashMap循环遍历方式及其性能对

ArrayList和LinkedList的几种循环遍历方式及性能对比分析(转)

主要介绍ArrayList和LinkedList这两种list的五种循环遍历方式,各种方式的性能测试对比,根据ArrayList和LinkedList的源码实现分析性能结果,总结结论. 通过本文你可以了解(1)List的五种遍历方式及各自性能 (2)foreach及Iterator的实现 (3)加深对ArrayList和LinkedList实现的了解. 阅读本文前希望你已经了解ArrayList顺序存储和LinkedList链式的结构,本文不对此进行介绍. 相关:HashMap循环遍历方式及其性

ios开发中的4种数据持久化方式【二、数据库 SQLite3、Core Data 的运用】

               在上文,我们介绍了ios开发中的其中2种数据持久化方式:属性列表.归档解档.本节将继续介绍另外2种iOS持久化数据的方法:数据库 SQLite3.Core Data 的运用: 在本节,将通过对4个文本框内容的创建.修改,退出后台,再重新回到后台,来认识这两种持久化数据的方式.效果图如下[图1]: [图1 GUI界面效果图] [本次开发环境: Xcode:7.2     iOS Simulator:iphone6S plus   By:啊左]     一.数据库SQL

【转】ArrayList和LinkedList的几种循环遍历方式及性能对比分析

原文网址:http://www.trinea.cn/android/arraylist-linkedlist-loop-performance/ 主要介绍ArrayList和LinkedList这两种list的五种循环遍历方式,各种方式的性能测试对比,根据ArrayList和LinkedList的源码实现分析性能结果,总结结论.通过本文你可以了解(1)List的五种遍历方式及各自性能 (2)foreach及Iterator的实现 (3)加深对ArrayList和LinkedList实现的了解.阅

C++的4种内存分配方式(抄的,备忘一下)

C++的4种内存分配方式 :堆.栈.自由存储区.全局/静态存储区和常量存储区 栈,就是那些由编译器在需要的时候分配,在不需要的时候自动清除的变量的存储区.里面的变量通常是局部变量.函数参数等.在一个进程中,位于用户虚拟地址空间顶部的是用户栈,编译器用它来实现函数的调用.和堆一样,用户栈在程序执行期间可以动态地扩展和收缩. 堆,就是那些由 new 分配的内存块,他们的释放编译器不去管,由我们的应用程序去控制,一般一个 new 就要对应一个 delete.如果程序员没有释放掉,那么在程序结束后,操作

C++以多态方式处理数组可能会遇到的问题

今天读<More Effective C++>时遇到一个条款:绝对不要以多态方式处理数组.以前自己也没有注意过,觉得有必要记录下来. C++是允许通过base class的指针或引用来操作derived class所形成的数组的.但发生的事情可能会令你感到意外.下面举例说明: 基类和派生类是这样的: class BST /*base class*/ { public: BST() : x1(1) {} virtual ~BST() { cout << "Good Bye