C语言进修教程第四章-数组(8)
当前位置:以往代写 > C/C++ 教程 >C语言进修教程第四章-数组(8)
2019-06-13

C语言进修教程第四章-数组(8)

C语言进修教程第四章-数组(8)

在二维数组a中选出各行最大的元素构成一个一维数组b。 a=3 16 87 65 4 32 11 108 10 25 12 37b=(87 108 37) 本题的编程思路是,在数组A的每一行中寻找最大的元素,找到之后把该值赋予数组B相应的元素即可。措施如下:
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;i<=2;i++)
printf("%5d",b[i]);
printf("\n");
}

措施中第一个for语句中又嵌套了一个for语句构成了双重轮回。外轮回节制逐行处理惩罚,并把每行的第0列元素赋予l。进入内轮回后,把l与后头各列元素较量,并把比l大者赋予l。内轮回竣事时l 即为该行最大的元素,然后把l值赋予b[i]。等外轮回全部完成时,数组b中已装入了a各行中的最大值。后头的两个 for语句别离输出数组a和数组b。

输入五个国度的名称按字母顺序分列输出。
本题编程思路如下:五个国度名应由一个二维字符数组来处理惩罚。然而C语言划定可以把一个二维数组当成多个一维数组处理惩罚。 因此本题又可以按五个一维数组处理惩罚, 而每一个一维数组就是一个国度名字符串。用字符串较量函数较量各一维数组的巨细,并排序, 输出功效即可。
编程如下:
void main()
{
char st[20],cs[5][20];
int i,j,p;
printf("input country’s name:\n");
for(i=0;i<5;i++)
gets(cs[i]);
printf("\n");
for(i=0;i<5;i++)
{ p=i;strcpy(st,cs[i]);
for(j=i+1;j<5;j++)
if(strcmp(cs[j],st)<0) {p=j;strcpy(st,cs[j]);}
if(p!=i)
{
strcpy(st,cs[i]);
strcpy(cs[i],cs[p]);
strcpy(cs[p],st);
}
puts(cs[i]);}printf("\n");
}

本措施的第一个for语句中,用gets函数输入五个国度名字符串。上面说过C语言答允把一个二维数组按多个一维数组处理惩罚, 本措施说明cs[5][20]为二维字符数组,可分为五个一维数组cs[0],cs[1],cs[2],cs[3],cs[4]。因此在gets函数中利用cs[i]是正当的。 在第二个for语句中又嵌套了一个for语句构成双重轮回。 这个双重轮回完成按字母顺序排序的事情。在外层轮回中把字符数组cs[i]中的国名字符串拷贝到数组st中,并把下标i赋予P。 进入内层轮回后,把st与cs[i]今后的各字符串作较量,若有比st小者则把该字符串拷贝到st中,并把其下标赋予p。内轮回完成后如p不便是 i 说明有比cs[i]更小的字符串呈现,因此互换cs[i]和st的内容。 至此已确定了数组cs的第i号元素的排序值。然后输出该字符串。在外轮回全部完成之后即完玉成部排序和输出。

本章小结

1.数组是措施设计中最常用的数据布局。数组可分为数值数组(整数组,实数组),字符数组以及后头将要先容的指针数组,布局数组等。

2.数组可以是一维的,二维的或多维的。

3.数组范例说明由范例说明符、数组名、数组长度 (数组元素个数)三部门构成。数组元素又称为下标变量。 数组的范例是指下标变量取值的范例。

4.对数组的赋值可以用数组初始化赋值, 输入函数动态赋值和赋值语句赋值三种要领实现。 对数值数组不能用赋值语句整体赋值、输入或输出,而必需用轮回语句逐个对数组元素举办操纵。

    关键字:

在线提交作业