1. Trang chủ
  2. » Công Nghệ Thông Tin

Tìm vị trí số hoàn thiện cuối cùng trong mảng 1 chiều các số nguyên nếu mảng không có số hoàn thiện thì trả về giá trị 1

3 1,8K 7

Đang tải... (xem toàn văn)

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Định dạng
Số trang 3
Dung lượng 27,85 KB

Các công cụ chuyển đổi và chỉnh sửa cho tài liệu này

Nội dung

Bài 139: Tìm vị trí số hoàn thiện cuối cùng trong mảng 1 chiều các số nguyên.

Trang 1

Bài 139: Tìm vị trí số hoàn thiện cuối cùng trong mảng 1 chiều các số nguyên Nếu mảng không có số hoàn thiện thì trả về giá trị -1

#include<stdio.h>

#include<conio.h>

#define MAX 100

void nhap (int a[], int &n)

{

do

{

printf("\nNhap so phan tu: ");

scanf("%d", &n);

if(n <= 0 || n > MAX)

{

printf("\nSo phan tu khong hop le Xin kiem tra lai !");

} }while(n <= 0 || n > MAX);

for( int i = 0; i < n; i++)

{

printf("\nNhap a[%d]: ", i);

scanf("%d", &a[i]);

}

}

void xuat(int a[], int n)

{

Trang 2

for( int i = 0; i < n; i++)

{

printf("%4d", a[i]);

}

}

bool kiemtrahoanthien(int n)

{

int i = 1;

int S = 0;

while(i < n)

{

if(n % i == 0)

{

S = S + i;

} i++;

}

if(S == n)

return true;

else

return false;

}

int timvitrihoanthiencuoi(int a[], int n) {

Trang 3

for( int i = n - 1; i >= 0; i )

{

if(kiemtrahoanthien(a[i]) == true)

{

return i;

} }

return -1;

}

int main()

{

int n;

int a[MAX];

nhap(a, n);

xuat(a, n);

int vitrihoanthiencuoi = timvitrihoanthiencuoi(a, n);

printf("\nVi tri hoan thien cuoi la %d", vitrihoanthiencuoi);

getch();

return 0;

}

Ngày đăng: 19/10/2016, 13:07

🧩 Sản phẩm bạn có thể quan tâm

w