数组

数组故名思议就是一组数据的集合。

int a[10];//可以存储10个整数

char  c[8];//可以存储8个字符‘

一般格式:数组类型 数组名[元素个数];

数组元素的访问:下标,a[2],a[0],a[4];//下标是从0开始的

下面是示例

 #include<stdio.h>

 //数组作为函数参数
void show(int a[],int n);
//逆序输出数组
void reverseArray(int a[],int n);
//输出最大值
int returnMax(int a[],int n );
//求数组元素的和
int returnSum(int a[],int n);
int main()
{
int a[];//定义
int nArray[] = {,,,,,,,,,};//定义并初始化 printf("%lu\n",sizeof(a));//数组的大小 = 数组类型*元素个数 //逐个赋值
a[] = ;
a[] = ;
a[] = ; //数组的使用,注意数组越界问题
int arrayLenght = sizeof(nArray)/sizeof(int);
int i = ;
while( i ++ < arrayLenght)//while循环实现遍历
{
printf("%d ",nArray[i]);
}
printf("\n");
show(a,);
reverseArray(a,);
printf("max :%d\n",returnMax(a,));
printf("sum:%d\n",returnSum(a,)); return ;
}
//数组作为函数参数,在形参列表中,int a[10] 实际意义是int *a;
void show(int a[],int n)//a是数组,n是元素个数
{
//不要再函数中对函数参数数组进行sizeof,因为,数组再函数参数中传递的实际是一个指针,即数组的首地址
// sizeof on array function parameter will return sizeof 'int *' instead of 'int []'
//printf("函数参数:%lu\n",sizeof(a));//数组的大小 = 数组类型*元素个数
for (int i = ; i < n; i ++)//for循环实现遍历
{
printf("%d ",a[i]);
}
printf("\n");
} //逆序输出数组
void reverseArray(int a[],int n)
{
while (n-- > ) {
printf("%d ",a[n]);
}
printf("\n");
} //输出最大值
int returnMax(int a[],int n )
{
int max = ;
for (int i = ; i < n; i ++)//for循环实现遍历
{
if (max < a[i])
{
max = a[i];//取得最大值
}
}
return max;
}
//求数组元素的和
int returnSum(int a[],int n)
{
int sum = ;
for (int i = ; i < n; i ++)//for循环实现遍历
{
sum += a[i];//累计求和
}
return sum;
}

二维数组以及多维数组

二位数组是一种特殊的一维数组:它的元素是一维数组。

二位数组就相当于一个表格,有行有列。

int a[3][2];//两行三列,如下图所示

a[0][0] a[0][1]
a[1][0] a[1][2]
a[2][0] a[2][2]

下标也是从零开始,数组名就是数组的地址,也就是第一个元素的地址a[0][0]

可以理解为三个一维数组:a[0],a[1],a[2].

  其中a[0] 包括a[0][0],a[0][1],

    a[1] 包括a[1][0],a[1][1],

    a[2] 包括a[2][0],a[2][1]

二维数组示例

 #include <stdio.h>

 //二维数组练习

 void show(int a[][],int h,int l);
int main()
{ //定义
int a[][];
//for循环初始化
for (int i= ; i < ; i++)
{
for (int j = ; j< ; j ++)
{
a[i][j] = i+j;
}
}
printf("length: %lu\n",sizeof(a));
//数组存储顺序,先行后列
printf("数组存储顺序\na[0]: %p\n",&a[]);
printf("a[1]: %p\n",&a[]);
printf("a[2]: %p\n",&a[]);
show(a,,); return ;
} void show(int a[][],int h,int l)
{
//数组名也是当做一个指针传进来的,int (*)[2];
//sizeof on array function parameter will return size of 'int (*)[2]' instead of 'int [3][2]'
// printf("%lu\n",sizeof(a)); //遍历数组,循环嵌套
for (int i= ; i < h; i++)
{
for (int j = ; j< l; j ++)
{
printf("%p\t",&a[i][j]);//数组存储顺序,先行后列
//printf("%d ",a[i][j]);
}
printf("\n"); }
printf("\n"); }

字符串

"hello" //这就是一个字符串,由多个字符组成,以字符\0结束,\0字符不可见。

字符串输出时用 %s。

字符串的长度:strlen函数获取字符处的长度,不包括\0字符

 #include <stdio.h>
#include <string.h>//strlen 函数头文件 //是否包含字符c,有得话返回,否则返回1
char containC(char str[],int n); //字符串
int main()
{
char c1[] = "jkhasdjkfhnkcdfdf";//系统自动添加结束字符 \0
char c2[] = {'','','','\0'};//这样赋值的话,要自己加上结束字符 \0
printf("%s\t %s\n",c1,c2);
printf("%lu\t %lu\n",strlen(c1),sizeof(c1));//strlen获得字符串长度,不包括\0 printf("%c\n",containC(c1,strlen(c1))); return ;
} //是否包含字符c,有得话返回,否则返回1
char containC(char str[],int n)
{
//循环遍历字符串
for (int i = ; i < n ; i ++)
{
if (str[i] == 'c')
{
return '';//找到返回1
}
}
return '';//找不到返回0
}

2015-4-11 今日如此,明日依旧。

最新文章

  1. css小技巧
  2. MFC 阶段学习总结
  3. 通过CDC获取 HDC
  4. js文档视口高度函数
  5. Linux Kernel中断子系统来龙去脉浅析【转】
  6. 1028 - Carl the Ant
  7. iOS 中的 block 是如何持有对象的
  8. Laravel教程:laravel 4安装及入门
  9. Windows下使用XManager访问Ubuntu 11.04的设置方法
  10. HUNNU11342:Chemistry(模拟)
  11. 封装GCD以及介绍如何使用
  12. C#去掉字符串头尾指定字符
  13. 中文版microbit:TurnipBit显示动态滚动字符教程实例
  14. Apache ab 单测 分布式
  15. Wordpress添加分类
  16. JavaScript Dom 事件
  17. [Ajax] 如何使用Ajax传递多个复选框的值
  18. 使用GetAdaptersInfo时,网卡类型的值为71
  19. JPI中常使用的类介绍:
  20. [eetcode 10]Regular Expression Matching

热门文章

  1. windows 下设置MTU数值
  2. Eucalyptus-利用镜像启动一个Centos实例
  3. JS浏览器获取宽高
  4. python3基础08(exec、bytearray使用等)
  5. Java反序列化漏洞详解
  6. SAP云平台CloudFoundry中的用户自定义变量
  7. 如何在SAP Server Side JavaScript里消费destination
  8. IOS 拖拽事件(手势识别)
  9. NSCopying
  10. flock文件锁