YOMEDIA
NONE

Hãy viết chương trình tìm vị trí giá trị dương nhỏ nhất trong mảng 1 chiều các số thực. Nếu mảng không có giá trị dương thì trả về -1

Theo dõi Vi phạm
ATNETWORK

Trả lời (1)

  • #include<stdio.h>

    #include<conio.h>

    #include<math.h>

    #define MAX 100

    void nhap (float 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("%f", &a[i]);

    }

    }

    void xuat(float a[], int n)

    {

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

    {

    printf("%8.3f", a[i]);

    }

    }

    int timvitriduongnhonhat(float a[], int n)

    {

    int i;

    int min;

    int dem = 0 ;

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

    {

    if(a[i] > 0) // kiểm tra xem có dương ?

    {

    dem++; // đếm số lượng số dương

    min = i; // i chính là vị trí min

    break; // vì giá trị dương đầu tiên là giá trị min

    }

    }

    if (dem == 0) // nếu không có giá trị dương

    return -1;

    for (i = i + 1; i < n; i++)

    {

    if((a[i] > 0) && (a[i] < a[min]))

    {

    min = i;

    }

    }

    return min;

    }

    int main()

    {

    int n;

    float a[MAX];

    nhap(a, n);

    xuat(a, n);

    int vitriduongnhonhat = timvitriduongnhonhat(a, n);

    printf("\nVi tri gia tri duong nho nhat la %d", vitriduongnhonhat);

    getch();

    return 0;

    }

      bởi sap sua 29/11/2021
    Like (0) Báo cáo sai phạm

Nếu bạn hỏi, bạn chỉ thu về một câu trả lời.
Nhưng khi bạn suy nghĩ trả lời, bạn sẽ thu về gấp bội!

Lưu ý: Các trường hợp cố tình spam câu trả lời hoặc bị báo xấu trên 5 lần sẽ bị khóa tài khoản

Gửi câu trả lời Hủy
 
NONE

Các câu hỏi mới

AANETWORK
 

 

YOMEDIA
ATNETWORK
ON