您的位置:

c语言对数组组,C语言数组运用

本文目录一览:

C语言中怎样实现对数组数据的删除、修改?

#includestdio.h

typedef struct Node{

int a,b;

}node;

node c[100];

int n;

void print(){

int i;

printf("\n当前数据:\n");

for(i=1;i=n;i++){

printf("第%d组:a=%d,b=%d\n",i,c[i].a,c[i].b);

}

printf("\n\n");

}//输出

void setnum(){

int i;

printf("输入n,表示共有n组数据:\n");

scanf("%d",n);

for(i=1;i=n;i++){

printf("输入第%d组数据的两个值a、b,用空格隔开:\n",i);

scanf("%d%d",c[i].a,c[i].b);

}

}//设置数据

void remove(){

int i,j;

printf("输入i,表示要删除第i数据:\n");

scanf("%d",i);

for(j=i;j=n-1;j++){

c[j]=c[j+1];

}//循环覆盖,让后一个覆盖前一个,所以j最大值取n-1

n--;//结构体中的元素减少1个

}//删除数据

void chang(){

int i,aa,bb;

printf("输入i,a,b,表示要将第i组数据修改成a、b:\n");

scanf("%d%d%d",i,aa,bb);

c[i].a=aa;

c[i].b=bb;//直接赋值修改

}//修改数据

main(){

int m;

while(1){

printf("输入:1-输入数据,2-修改数据,3-删除数据\n 4-输出数据,0-退出\n");

scanf("%d",m);

if(m==0) break;

else if(m==1) setnum();

else if(m==2) chang();

else if(m==3) remove();

else if(m==4) print();

}

}

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("%5d",a[i][j]);

printf("\n");

}

printf("\narray b:\n");

for(i=0;i3;i++)

printf("%5d",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语言怎么定义数组

首先双击启动visual studio 2015,如果你使用的是其他版本的vs也是可以的。单击“文件”-“新建”-“项目”,选择visual c++,然后是“空项目”。

12怎么下载visual studio2015及安装教程

请点击输入图片描述

单击“解决方案资源管理器”,右键源文件-添加--新建项,选择c++文件,最后单击添加。

请点击输入图片描述

第一种方法:

一维数组:

int arry1[10];

float arry2[100];

定义了2个一维数组,一个名为arry1的整形数组,有1个元素;arry2为实型数组,有100个元素,注意数组下标是从0开始的,不是从1开始,比如arry1的第一个数组为arry[0]不是arry[1]。

请点击输入图片描述

对数组赋值或者部分赋值:

int x[5] = { 1,2,3,4,5 };

int x[5] = { 1,2,3,};

第一个表示x[0]=1,x[1]=2,x[2]=3,x[3]=4,x[4]=5;第二个表示对前三个元素赋值,后面的元素都为0,x[0]=1,x[1]=2,x[2]=3,x[3]=0,x[4]=0;

请点击输入图片描述

二维数组:

一般形式:数组名[下标1][下标2],下标也是从0开始表示是第一个元素。比如:

int x[1][2];定义了一个名为x的整型的1行2列的二维数组。

请点击输入图片描述

对二维数组赋值:

int x[2][2] = { {1,2},{3,4} };

表示x[0][0]=1,x[0][1]=2,x[1][0]=3,x[1][1]=4,x[0][0]表示第一行第一列,其他依次类推。

请点击输入图片描述