c语言函数里的数组 c语言数组函数库

C语言中的数组什么意思?所谓数组,是有序的元素序列 。数组是在程序设计中,为了处理方便,把具有相同类型的若干元素按无序的形式组织起来的一种形式 。这些无序排列的同类数据元素的集合称为数组 。
比如油烟机的风扇转速会和工作的模式之间有一定的关系,那么我们就可以把它的工作模式和一维数组的下标对应起来 , 我们将具体的转速放在数组中,这样的话就非常方便我们在日后查询 。
再比如说家中的冷暖灯光控制这方面,色温灯里会有两个灯珠,分别对应的是冷光和暖光,选择不同的模式灯光的颜色就不同,我们就可以将这两种灯光的亮度pwm值事先放在二维数组中 , 以便调用调光 。
在程序中合理地使用数组,会使程序的结构比较整齐,而且可以把较为复杂的运算 , 转化成简单的数组来表示 。
扩展资料:
一、使用规则:
1、可以只给部分元素赋初值 。当{ }中值的个数少于元素个数时,只给前面部分元素赋值 。
2、只能给元素逐个赋值 , 不能给数组整体赋值 。
(请注意:在C、C#语言中是这样,但并非在所有涉及数组的地方都这样,数据库是从1开始 。)
3、若不给可初始化的数组赋初值 , 则全部元素均为0值 。
4、假如给全部元素赋值,则在数组说明中,可以不给出数组元素的个数 。
动态赋值可以在程序执行过程中,对数组作动态赋值 。这时可用循环语句配合scanf函数逐个对数组元素赋值 。
二、表示方法:
数组元素是组成数组的基本单元 。
数组元素也是一种变量,其标识方法为数组名后跟一个下标 。下标表示了元素在数组中的顺序号 。数组元素的一般形式为:数组名[下标] 其中的下标只能为整型常量或整型表达式 。
如为小数时 , C编译将自动取整 。例如,a[5],a[i j],a[i]都是合法的数组元素 。数组元素通常也称为下标变量 。必须先定义数组,才能使用下标变量 。在C语言中只能逐个地使用下标变量,而不能一次引用整个数组 。
参考资料:百度百科-数组
C语言中的数组是什么意思?把具有相同数据类型的若干变量按有序的形式组织起来,
以便于程序处理 , 这些数据元素的集合就是数组,按照数组
元素的类型不同 , 可分为:数值数组、字符数组、指针数组
结构数组等各种类别 。
数组说明的一般形式为:
类型说明符 数组名[常量表达式],......;
其中类型说明符可以是任一种基本数据类型或构造数据类型
数组名是定义的数组标识符 。常量表达式表示数据元素的个
数,也就是数组的长度 。
对数组类型的说明应注意:
1)数组的类型实际上是数组元素的取值类型 。
2)数组名的书写应符合标识符的书写规范 。
3)数组名不能与其他变量名相同 。
4)常量表达式表示数组元素的个数,但是其下标从0开始计算
5)不能在方括号中用变量来表示元素的个数,但是可以用符号
常数或常量表达式 。
6)允许在同一个类型说明中,说明多个数组和多个变量 。
数组元素的表示方法
一般比较简单就是数组名[下标]来引用,先定义后用 , 如果
是小数的话 , 直接自动取整 。
数组赋值分为:初始化赋值和动态赋值
初始化赋值一般形式为:
static 类型说明符 数组名[常量表达式]={值,值......};
static表示静态存储类型 , c语言规定只有静态存储数组和外部数组
才可做初始化赋值 。
c语言对数组的初始化赋值还有几个规定:
1)可以只给部分元素赋值 。
2)只能给元素逐个赋值,不能给数组整体赋值 。
3)如不给可初始化的数组赋初值,在在数组说明中,可以不给出数组
元素的个数 。
下面看一下多维数组
主要看一下二维数组,其他的就可以用二维数组类推得到
二维数组的类型说明的一般形式是:
类型说明符 数组名[常量表达式1][常量表达式2]...;
在c语言中二维数组是按行排列的
二维数组的表示方法:
数组名[下标][下标]
二维数组的初始化
二维数组初始化也是在类型说明时给各下标变量赋以初值 。二维数组可
按行分段赋值,也可按行连续赋值 。
二维数组的初始化还应该注意:
1)可以只对部分元素赋初值,未赋初值的元素自动取为0 。
2)如对全部元素赋初值,则第一维的长度可以不给出 。
字符数组:
用来存放字符变量的数组称为字符数组 。
C语言允许用字符串的方式对数组作初始化赋值 。例如:
static char c[]={'c', ' ','p','r','o','g','r','a','m'}; 可写为:
static char c[]={"C program"}; 或去掉{}写为:
sratic char c[]="C program";
用字符串方式赋值比用字符逐个赋值要多占一个字节 , 用于存放字符串结
束标志'\0' 。上面的数组c在内存中的实际存放情况为: C program\0`\0'是
由C编译系统自动加上的 。由于采用了`\0'标志,所以在用字符串赋初值时一
般无须指定数组的长度 , 而由系统自行处理 。在采用字符串方式后,字符数
组的输入输出将变得简单方便 。除了上述用字符串赋初值的办法外,还可用
printf函数和scanf函数一次性输出输入一个字符数组中的字符串,而不必
使用循环语句逐个地输入输出每个字符 。
void main()
{
static char c[]="BASIC\ndBASE";
printf("%s\n",c);
} printf("%s\n",c);
注意在本例的printf函数中 , 使用的格式字符串为"%s",表示输出的是一
个字符串 。而在输出表列中给出数组名则可 。不能写为: printf("%s",c[]);
void main()
{
char st[15];
printf("input string:\n");
scanf("%s",st);
printf("%s\n",st);
} char st[15];
本例中由于定义数组长度为15,因此输入的字符串长度必须小于15,
以留出一个字节用于存放字符串结束标志`\0` 。应该说明的是,对一个字
符数组,如果不作初始化赋值,则必须说明数组长度 。还应该特别注意的是 ,
当用scanf函数输入字符串时,字符串中不能含有空格,否则将以空格作为串
的结束符 。例如运行例4.8,当输入的字符串中含有空格时,运行情况为:
input string:this is a book this 从输出结果可以看出空格以后的字符
都未能输出 。为了避免这种情况,可多设几个字符数组分段存放含空格的
串 。程序可改写如下:
Lesson
void main()
{
char st1[6],st2[6],st3[6],st4[6];
printf("input string:\n");
scanf("%s%s%s%s",st1,st2,st3,st4);
printf("%s %s %s %s\n",st1,st2,st3,st4);
}
本程序分别设了四个数组,输入的一行字符的空格分段分别装入四个数组 。
然后分别输出这四个数组中的字符串 。在前面介绍过,scanf的各输入项必须以
地址方式出现,如 a,b等 。但在例4.8中却是以数组名方式出现的,这是为
什么呢?这是由于在C语言中规定,数组名就代表了该数组的首地址 。整个
数组是以首地址开头的一块连续的内存单元 。如有字符数组char c[10],在
内存可表示如图4.2 。设数组c的首地址为2000 , 也就是说c[0]单元地址为2000 。
则数组名c就代表这个首地址 。因此在c前面不能再加地址运算符 。如写作
scanf("%s",c);则是错误的 。在执行函数printf("%s",c) 时,按数组名c
找到首地址,然后逐个输出数组中各个字符直到遇到字符串终止标志'\0'为止 。
字符串常用函数:
用于输入输出的字符串函数在使用前应包含头文件"stdio.h",使用其他字符串
函数则应包含头文件"string.h".下面介绍几个常用的字符串函数:
1)字符串输出函数 puts 格式:puts(字符数组名) 功能:把字符数组中的字符
串输出到显示器 。
#include"stdio.h"
main()
{
static char c[]="BASIC\ndBASE";
puts(c);
}
2)字符串输入函数gets 格式:gets(字符数组名) 功能:从标准输入设备上
输入一个字符串 。
#include"stdio.h"
main()
{
char st[15];
printf("input string:\n");
gets;
puts;
}
tips:gets函数并不以空格作为字符串输入结束的标志,而只是以回车作为输入
结束,这是与scanf不同的部分
3)字符串连接函数strcat 格式:strcat(字符数组名1,字符数组名2)
功能:把字符数组2中的字符串连接到字符数组1中字符串后面,并删去字符串
1后的串标志"\0",本函数返回字符数组1的首地址 。
#include"string.h"
main()
{
static char st1[30]="My name is ";
int st2[10];
printf("input your name:\n");
gets(st2);
strcat(st1,st2);
puts(st1);
}
4)字符串拷贝函数strcpy 格式:strcpy(字符数组名1,字符数组名2)
功能:把字符数组2中的字符串拷贝到字符数组1中,串结束标志 "\0"也一同
拷贝,字符数组2也可以是一个字符常量,就相当于把一个字符串赋予一个字符数组
#include"string.h"
main()
{
static char st1[15],st2[]="C Language";
strcpy(st1,st2);
puts(st1);
printf("\n");
}
5)字符串比较函数strcmp格式:strcmp(字符数组1 , 字符数组2) 功能:
按照ASCII码顺序比较两个数组中的字符串,并有函数返回值返回比较结果
#include"string.h"
main()
{
int k;
static char st1[15],st2[]="C Language";
printf("input a string:\n");
gets(st1);
k=strcmp(st1,st2);
if(k==0) printf("st1=st2\n");
if(k0) printf("st1st2\n");
if(k0) printf("st1st2\n");
}
6)测字符串长度的函数strlen 格式:strlen(字符数组名) 功能:
测字符串的实际长度(不含字符串结束标志"\0")并作为函数返回值
#include"string.h"
main()
{
int k;
static char st[]="C Language";
k=strlen;
printf("The lenth of the string is %d\n",k);
}
程序举例:
例一:
main()
{
int i,j,p,q,s,n,a[11]={127,3,6,28,54,68,87,105,162,18};
for(i=0;i10;i)
{
p=i;q=a[i];
for(j=i 1;j10;j)
if(qa[j]) {p=j;q=a[j];}
if(p!=i)
{
s=a[i];
a[i]=a[p];
a[p]=s;
}
printf("%d",a[i]);
}
printf("\ninput number:\n");
scanf("%d",n);
for(i=0;i10;i)
if(na[i])
{for(s=9;s=i;s--) a[s 1]=a[s];brbreak;}
a[i]=n;
for(i=0;i10;i)
printf("%d",a[i]);
printf("\n");
}
例二:
main()
{
static int a[][4]={3,16,87,65,4,32,11,108,10,25,12,27};
int b[3],i,j,l;
for(i=0;i=2;i)
{
l=a[i][0];
for(j=1;j=3;j)
if(a[i][j]l) l=a[i][j];
b[i]=l;
}
printf("\narray a:\n");
for(i=0;i=2;i)
{
for(j=0;j=3;j)
printf("]",a[i][j]);
printf("\n");
}
printf("\narray b:\n");
for(i=0;i3;i)
printf("]",b[i]);
printf("\n");
}
例三:
void main()
{
char st[20],cs[5][20];
int i,j,p;
printf("input country's name:\n");
for(i=0;i5;i)
gets(cs[i]);
printf("\n");
for(i=0;i5;i)
{
p=i;strcpy(st,cs[i]);
for(j=i 1;j5;j)
if(strcmp(cs[j],st)0) {p=j;strcpy(st,cs[j]);}
if(p!=i)
{strcpy(st,cs[i]);brstrcpy(cs[i],cs[p]);brstrcpy(cs[p],st);br}
puts(cs[i]);
printf("\n");
在C语言中怎么将子函数中的数组和函数调用出来?来传送子函数中的数组有多种方法——可以通过函数返回值返回地址传递数组;也可以通过函数输入参数来传递数组;还可以通过全局变量来传递数组 。
子函数本身可以直接在作用域中进行调用 。
1、通过函数返回值返回地址传递数组 。
声明函数时需要声明函数返回值类型为对应数组的地址,此时可以返回数组的地址 , 结合数组元素的地址关系可以传递整个数组,同时可以根据数组的特性传递多个参数 。
2、通过输入参数传递数组 。
声明函数时提供空输入参数,调用函数时提供目标数组,即可以通过该数组调用子函数中的数组 , 该方法也可以用于传递多个参数 。
3、通过全局变量来传递数组 。
声明全局变量用于存储子函数中的数组,此时可以在全局变量作用域中读取调用子函数的数组 。
注意:子函数是C语言模块化编程思想的核心,其方法是通过输入接口和输出接口实现对黑盒的调用,故对其内部数据的输入和调用也需要通过输入接口、输出接口和程序的公共区域实现 。
C语言,在函数里要输入一个数组怎么办用指针就可以c语言函数里的数组了,如
定义有int a[5];
则这样定义函数:
int fun(int *p, int size)
{
//p为数组c语言函数里的数组的首地址
//size为数组c语言函数里的数组的大小
//传递进去后可以像操作a一样用下标操作p
//如p[0], p[4]...
}
传递参数给函数可以这样写:
fun(a, 5);
若是多维数组,则第一维大小不给出,只指定后面的维数大小,如:
定义有int a[5][2];
则这样定义函数:
int fun(int p[][2], int size)
{
//p为数组的首地址
//size为第一维的大小
//传递进去后可以像操作a一样用下标操作p
//如p[0][1], p[4][1]...
}
传递参数给函数可以这样写:
fun(a, 5);
C语言中自定义的函数中有数组,应该如何运用该函数方法
有2
将该数组定义为全局变量,即:
int
g_arr;
void
fun()
{...}
void
main()
{...}
2.将该数组作为函数参数传递到自定义函数里,即:
void
fun(int
arr[])
{...}
void
main()
{
int
arr[10];
fun(arr);
}
关于c语言函数,函数里的数组在函数结束后是不是就释放了?line数组会在函数执行结束后释放,因为它属于函数里的局部变量 。
所谓的释放不是说这个数组已经消失得无影无踪 , 而是说它现在所占据的空间可以由其他数据再次使用(即覆盖) , 我们不要再去访问这个line数组了,因为它的内容随时可变 。
【c语言函数里的数组 c语言数组函数库】c语言函数里的数组的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于c语言数组函数库、c语言函数里的数组的信息别忘了在本站进行查找喔 。

    推荐阅读