/* Bài 152/60/SBT Thầy NTTMK:Làm cách 2:Hãy tìm "số hoàn thiện nhỏ nhất" trong mảng một chiều các số nguyên.Nếu mảng không có số hoàn thiện thì trả về giá trị 0. 135.cpp */
/* Ở đây chương trình còn cho phép liệt kê ra tất cả các số hoàn thiện có trong mảng và số lượng của chúng,liệt kê ra số hoàn thiện nhỏ nhất kèm theo vị trí của nó. */
/*
Tác giả: Nguyễn Việt Nam Sơn
Trung tâm đào tạo tin học - Thiết kế phần mềm - Sơn Đẹp Trai: www.SonDepTrai.com
Nguồn source code này Tôi viết vào năm 2012 lúc mới bắt đầu học lập trình C/C++ nên một số cách sẽ không được tối ưu - Bạn chỉ nên dùng trên tinh thần tham khảo thôi nhé.
Mong giúp đỡ được Bạn trên con đường Học Lập Trình.
TẤT CẢ VÌ SỰ THÀNH CÔNG CỦA BẠN
*/
#include<stdio.h>
#include<conio.h>
#include<limits.h>
#define MAX 100
#define bool
void nhapmang(int a[MAX],int &n)
{
do{
printf("Nhap vao so phan tu cua mang:n=");
scanf("%d",&n);
if(n<1||n>MAX)
printf("So ban nhap vao khong hop le!Xin ban vui long nhap lai!\n");
else
break;
}while(n<1||n>MAX);
for(int i=0;i<n;i++)
{
printf("Nhap vao a[%d]=",i);
scanf("%d",&a[i]);
}
}
void xuatmang(int a[MAX],int n)
{
printf("\n>>>>>>>>>>>>>>>MANG VUA NHAP LA:<<<<<<<<<<<<<<<<<\n");
for(int i=0;i<n;i++)
{
printf("%4d",a[i]);
}
printf("\n");
}
void xulydulieu(int a[MAX],int n)
{
int Co,dem=0,vitri=0,min=INT_MAX,Co1;
bool Co=false;
bool Co1=false;
printf("Trong mang co cac so hoan thien la:");
for(int i=0;i<n;i++)
{
int tong=0; // tong=0 phải để ở trong vòng lặp thì mới hiển thị ra được kết quả.
for(int k=1;k<a[i];k++)
{
if(a[i]%k==0)
{
tong+=k;
if(tong==a[i])
{
printf("%4d",a[i]);
dem++;
Co=true;
if(a[i]<min)
{
min=a[i];
vitri=i;
Co1=true;
}
}
}
}
}
if(Co==true)
printf("\nCo %d so hoan thien trong mang",dem);
else
printf("\n0");
if(Co1==true)
printf("\nSo hoan thien nho nhat co trong mang la:%d tai vi tri:%d",min,vitri);
}
void main()
{
int a[MAX],n,NAMSON;
quaylai:nhapmang(a,n);
xuatmang(a,n);
xulydulieu(a,n);
printf("\nBan co muon tiep tuc chay chuong trinh khong ? Neu co bam phim C,nguoc lai bam bat ky phim nao khac de ket thuc\n");
NAMSON=getch();
if(NAMSON=='c'||NAMSON=='C')
goto quaylai;
}