第六章 例题

【例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);
}

运行结果:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值