/
XkqRc8Nw.cpp
92 lines (82 loc) · 1.73 KB
/
XkqRc8Nw.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
/*
Sưu tầm bởi @nguyenvanhieuvn
Thực hành nhiều bài tập hơn tại https://luyencode.net/
*/
#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]);
}
}
// Tạo mảng b chứa các khoảng cách từ x đến các giá trị trong mảng a
void TaoMang(float a[], int n, float b[], int x)
{
for(int i = 0; i < n; i++)
{
b[i] = abs(x - a[i]);
}
}
// Tìm max của mảng b
float TimMax(float b[], int n)
{
int Max = b[0];
for (int i = 1; i < n; i++)
{
if (b[i] > Max)
{
Max = b[i];
}
}
return Max;
}
void XuatKetQua(float a[], float b[], int n)
{
printf("\nGia tri trong mang xa gia tri x nhat la: ");
int Max = TimMax(b, n);
for (int i = 0; i < n; i++)
{
if (b[i] == Max)
{
printf("%8.3f", a[i]); // Đối chiếu qua mảng a, in phần tử ở vị trí thứ i thỏa ĐK
}
}
}
int main()
{
int n;
float a[MAX];
float b[MAX];
nhap(a, n);
xuat(a, n);
float x;
printf("\nNhap vao gia tri x: ");
scanf("%f", &x);
TaoMang(a, n, b, x);
printf("\nKhoang cach tu x = %.3f den cac phan tu trong mang la:\n", x);
xuat(b, n);
XuatKetQua(a, b, n);
getch();
return 0;
}