【例6.1】 编程求出1000以内的完数。
#include <stdio.h>
int main()
{
int arr[999] = { 0 };
int sum = 0;
for (int num = 6; num <= 1000; num++)
{
for (int i = 1; i < num; i++)
{
if (num % i == 0)
{
sum += i;
arr[i - 1] = i;
}
else
arr[i - 1] = 0;
}
if (sum == num)
{
printf("%d its factors are ", num);
for (int i = 0; i < num; i++)
{
if (arr[i] > 0)
printf("%d ", arr[i]);
}
printf("\n");
}
sum = 0;
}
system("pause");
return 0;
}
运行结果:
【例6.2】 输入10种商品的价格,计算应付金额。
#include<stdio.h>
int main()
{
float k[10];
int i;
float sum=0;
printf("请输入商品的价格:\n");
for(i=0;i<=9;i++)
{
printf("%d: ",i+1);
scanf("%f",&k[i]);
}
for(i=0;i<=9;i++)
printf("第%d件商品的价格:%6.2f\n",i+1,k[i]);
printf("\n\n");
for(i=0;i<=9;i++)
sum=sum+k[i];
printf("应付金额=%6.2f元\n",sum);
return 0;
}
运行结果:
【例6.3】 输入5个数,逆序输出
#include<stdio.h>
int main()
{
int a[5];
int i;
printf("输入5个数组元素:\n");
for(i=0;i<5;i++)
scanf("%d",&a[i]);
printf("原始数组为:\n");
for(i=0;i<5;i++)
printf("%5d",a[i]);
printf("\n");
printf("逆序后的数组为:\n");
for(i=4;i>=0;i--)
printf("%5d",a[i]);
printf("\n");
return 0;
}
运行结果:
【例6.4】 为指定的数组输入10个数据,并求这些数据之和。
#include<stdio.h>
int main()
{
int n=10,i,sum=0;
int a[10];
for(i=0;i<10;i++)
{
scanf("%d",&a[i]);
sum=sum+a[i];
}
printf("sum=%d\n",sum);
return 0;
}
运行结果:
【例6.5】 二维数组的转置(将二维数组行列元素互换,存到另一个数组中)
#include<stdio.h>
int main()
{
int a[2][3]={{1,2,3},{4,5,6}};
int b[3][2],i,j;
printf("array a:\n");
for(i=0;i<2;i++)
{
for(j=0;j<3;j++)
{ printf("%5d",a[i][j]);
b[j][i]=a[i][j];
}
printf("\n");
}
printf("array b:\n");
for(i=0;i<3;i++)
{
for(j=0;j<2;j++)
printf("%5d",b[i][j]);
printf("\n");
}
return 0;
}
运行结果:
【例6.6】 .定义一个三行列的二维数组,初始化为如下值,后求二维数组中最大元素值及其行列号
1 2 3 4
9 8 7 6
-10 10 -5 2
#include<stdio.h>
int main()
{
int i,j,row=0,colum=0,max;
int a[3][4]={1,2,3,4,9,8,7,6,-10,10,-5,2};
max=a[0][0];
for(i=0;i<3;i++)
for(j=0;j<4;j++)
if(a[i][j]>max)
{
max=a[i][j];
row=i;
colum=j;
}
printf("max=%d\nrow=%d\ncolum=%d\n",max,row,colum);
return 0;
}
运行结果:
【例6.7】 读入下表中值到数组,分别求各行、各列及表中所有数之和
#include <stdio.h>
void main()
{ int x[5][4],i,j;
for(i=0;i<4;i++)
for(j=0;j<3;j++)
scanf("%d",&x[i][j]);
for(i=0;i<3;i++)
x[4][i]=0;
for(j=0;j<5;j++)
x[j][3]=0;
for(i=0;i<4;i++)
for(j=0;j<3;j++)
{ x[i][3]+=x[i][j];
x[4][j]+=x[i][j];
x[4][3]+=x[i][j];
}
for(i=0;i<5;i++)
{ for(j=0;j<4;j++)
printf("%5d\t",x[i][j]);
printf("\n");
}
}
运行结果:
【例6.8】 求矩阵对角线的和
#include<stdio.h>
int main()
{
int a[3][3];
int i,j,sum=0;
for(i=0;i<3;i++)
for(j=0;j<3;j++)
scanf("%d",&a[i][j]);
for(i=0;i<3;i++)
{for(j=0;j<3;j++)
printf("%5d",a[i][j]);
printf("\n");}
for(i=0;i<3;i++)
for(j=0;j<3;j++)
{if(i==j)
sum=sum+a[i][j];
else
continue;
}
printf("sum=%d\n",sum);
}
运行结果: