1楼:人也是
//切记一点数组名代表数组的首地址,还有就是arr[i] == *(arr + i)#include int main(void); int len = 5; int i,*p; p = arr; //第一种循环数组的方法 printf("第一种循环数组的方法:\n"); for(i=0;i
2楼:殷秀梅森烟
int*p[n];-----指针数组,每个元素均为指向整型数据的指针。
int(*)p[n];------p为指向一维数组的指针,这个一维数组有n个整型数据。
int*p();----------函数带回指针,指针指向返回的值。
int(*)p();------p为指向函数的指针。
c语言中find(数组名,数字)有什么作用
3楼:匿名用户
这个是自定义函数
一般是查找的功能
也就是查找数组中,值为数字的那个元素。
具体还得看实现。
c语言中数组名直接加数字的用法?请举例
4楼:曾杨氏汝雁
inta[3];//声明一个3个元素的数组。。这3个元素都是int类型的,分别是
a[0]
a[1]
a[2]
//使用的时候您可以当普通回变量使用。。比如答a[0]=1;
a[1]=2;
a[2]
=a[1]
+a[0];
printf("%d",
a[2]);
//您用a[10]情况类似,只是元素有10个,分别是0,1,2,……,9,注意,数组元素下标都是从0开始。。
就是这样,如果有不明白的您再问吧。。
5楼:月猫狗
//切记一bai点数组名代表数组的du首地址,还有就是arr[i]==*(arr+i)
#include
intmain(void);
intlen=5;
inti,*p;
p=arr;
//第一种zhi循环数组dao的方法
printf("第一种循环数组的方法:\n");
for(i=0;i
6楼:帥氣的我
int a[5];
scanf("%d",a+1);这就代表大会a1的地址
c语言中的数组是什么意思?
7楼:手机用户
把具有相同数据类型的若干变量按有序的形式组织起来,
以便于程序处理,这些数据元素的集合就是数组,按照数组
元素的类型不同,可分为:数值数组、字符数组、指针数组
结构数组等各种类别。
数组说明的一般形式为:
类型说明符 数组名[常量表达式],......;
其中类型说明符可以是任一种基本数据类型或构造数据类型
数组名是定义的数组标识符。常量表达式表示数据元素的个
数,也就是数组的长度。
对数组类型的说明应注意:
1)数组的类型实际上是数组元素的取值类型。
2)数组名的书写应符合标识符的书写规范。
3)数组名不能与其他变量名相同。
4)常量表达式表示数组元素的个数,但是其下标从0开始计算
5)不能在方括号中用变量来表示元素的个数,但是可以用符号
常数或常量表达式。
6)允许在同一个类型说明中,说明多个数组和多个变量。
数组元素的表示方法
一般比较简单就是数组名[下标]来引用,先定义后用,如果
是小数的话,直接自动取整。
数组赋值分为:初始化赋值和动态赋值
初始化赋值一般形式为:
static 类型说明符 数组名[常量表达式]=;
static表示静态存储类型,c语言规定只有静态存储数组和外部数组
才可做初始化赋值。
c语言对数组的初始化赋值还有几个规定:
1)可以只给部分元素赋值。
2)只能给元素逐个赋值,不能给数组整体赋值。
3)如不给可初始化的数组赋初值,在在数组说明中,可以不给出数组
元素的个数。
下面看一下多维数组
主要看一下二维数组,其他的就可以用二维数组类推得到
二维数组的类型说明的一般形式是:
类型说明符 数组名[常量表达式1][常量表达式2]...;
在c语言中二维数组是按行排列的
二维数组的表示方法:
数组名[下标][下标]
二维数组的初始化
二维数组初始化也是在类型说明时给各下标变量赋以初值。 二维数组可
按行分段赋值,也可按行连续赋值。
二维数组的初始化还应该注意:
1)可以只对部分元素赋初值,未赋初值的元素自动取为0。
2)如对全部元素赋初值,则第一维的长度可以不给出。
字符数组:
用来存放字符变量的数组称为字符数组。
c语言允许用字符串的方式对数组作初始化赋值。例如:
static char c=; 可写为:
static char c=; 或去掉{}写为:
sratic char c="c program";
用字符串方式赋值比用字符逐个赋值要多占一个字节, 用于存放字符串结
束标志'\0'。上面的数组c在内存中的实际存放情况为: c program\0`\0'是
由c编译系统自动加上的。由于采用了`\0'标志,所以在用字符串赋初值时一
般无须指定数组的长度, 而由系统自行处理。在采用字符串方式后,字符数
组的输入输出将变得简单方便。 除了上述用字符串赋初值的办法外,还可用
printf函数和scanf函数一次性输出输入一个字符数组中的字符串, 而不必
使用循环语句逐个地输入输出每个字符。
void main()
printf("%s\n",c);
注意在本例的printf函数中,使用的格式字符串为"%s", 表示输出的是一
个字符串。而在输出表列中给出数组名则可。 不能写为: printf("%s",c);
void main()
char st[15];
本例中由于定义数组长度为15, 因此输入的字符串长度必须小于15,
以留出一个字节用于存放字符串结束标志`\0`。 应该说明的是,对一个字
符数组,如果不作初始化赋值,则必须说明数组长度。还应该特别注意的是,
当用scanf函数输入字符串时,字符串中不能含有空格,否则将以空格作为串
的结束符。例如运行例4.8,当输入的字符串中含有空格时,运**况为:
input string:this is a book this 从输出结果可以看出空格以后的字符
都未能输出。 为了避免这种情况, 可多设几个字符数组分段存放含空格的
串。程序可改写如下:
lesson
void main()
本程序分别设了四个数组, 输入的一行字符的空格分段分别装入四个数组。
然后分别输出这四个数组中的字符串。在前面介绍过,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()
2)字符串输入函数gets 格式:gets(字符数组名) 功能:从标准输入设备上
输入一个字符串。
#include"stdio.h"
main()
tips:gets函数并不以空格作为字符串输入结束的标志,而只是以回车作为输入
结束,这是与scanf不同的部分
3)字符串连接函数strcat 格式:strcat(字符数组名1,字符数组名2)
功能:把字符数组2中的字符串连接到字符数组1中字符串后面,并删去字符串
1后的串标志"\0",本函数返回字符数组1的首地址。
#include"string.h"
main()
4)字符串拷贝函数strcpy 格式:strcpy(字符数组名1,字符数组名2)
功能:把字符数组2中的字符串拷贝到字符数组1中,串结束标志 "\0"也一同
拷贝,字符数组2也可以是一个字符常量,就相当于把一个字符串赋予一个字符数组
#include"string.h"
main()
5)字符串比较函数strcmp格式:strcmp(字符数组1,字符数组2) 功能:
按照ascii码顺序比较两个数组中的字符串,并有函数返回值返回比较结果
#include"string.h"
main()
a[i]=n;
for(i=0;i<10;i++)
printf("%d",a[i]);
printf("\n");
}例二:
main()
;int b[3],i,j,l;
for(i=0;i<=2;i++)
printf("\narray a:\n");
for(i=0;i<=2;i++)
printf("\narray b:\n");
for(i=0;i<3;i++)
printf("%5d",b[i]);
printf("\n");
}例三:
void main()
if(p!=i)
puts(cs[i]);
printf("\n");
c语言,编写find函数,在一维数组x中查找是否有key,若有返回该数组元素下标,否则返回1。
8楼:匿名用户
#include
intfind(int*a,intn,intkey) //inta[10]里的10没有意义,直接写inta或int*a,一个意思
return-1;//我觉得返回-1更合理,非要返回1的话你自己改吧
}voidmain()
c语言中,数组名的前面加*, 如a[3][4]; *a输出的是什么结果
9楼:花儿朵朵
由于a[3][4]是个二维数组,数组名是数组的首地址,也是一维a[3]的首地址,也是一维第一个元素a[0][0]的首地址,因此a a[0] a[0][0]三个的地址是相同的,那么*a在这里代表什么呢,*在这里代表的是取值符,而不是指针符号,由于a是个二维数组,*a代表的是取第一维的首元素,而这里一维里的元素本身又是一个一维数组,因此在a的第一维中是存放着三个一维元素的首地址,显然*a取到的就是第一维里第一个元素的首地址了,*(a+1)就是取到第一维里第二个元素的首地址了,你可以建一个一维数组int arr = 测试一下,在一维数组中,*arr代表的就是取第一个元素的值,它的值是个int型数值,也就是第1个元素1,而二维数组中的a[3]里存放的是三个元素(3个一维数组)的首地址,因此得出一个结论,二维数组里的第一维就是一个指针数组,每个指针指向三个元素(3个一维数组)的首地址。从而**a就是取第一维里第一个元素(1维数组)里的第1个元素的值。
c语言c中间加数字是什么意思,C语言%c中间加数字是什么意思
1楼 灰灰不吃羊 限制输出宽度, 2c,就是输出的宽度为2, c省略了1,c的输出格式控制会有详细的介绍。 c语言里 f中间加数字是什么意思 2楼 匿名用户 f是用于格式化输入输出函数,对应类型为float的格式字符。加数字的情况仅适用于输出函数,比如printf。 其形式为 printf a bf...
c语言中数组名和指针变量的区别,C语言中数组名和指针的区别
1楼 销 数组名除了sizeof会返回数组大小,其他的实况下是相当于一个指针常量无区别的 指针常量也就是说,不能改变数组名的值,比如int a 10 a a a a 10等都是非法的 c语言中数组名和指针的区别 2楼 匿名用户 数组在当作参数传递时,可以当作指针 当然,参数传递相当于赋值操作,所以用...
c语言中多维数组下标问题,C语言中多维数组下标问题?
1楼 匿名用户 假如 int a 30 int b 15 a b 10 b就是下标变量, a 3 111 3就是下标 a 0 ,a 1 ,a 2 不能当作下标变量使用,他们是数组名,不是一个单纯的下标变量! 就是说不能 a a 4 100这样用 大概是这个意思 我没试过。。。。 2楼 算o你o狠 下...