-
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathArrayExercise.java
More file actions
64 lines (58 loc) · 1.94 KB
/
Copy pathArrayExercise.java
File metadata and controls
64 lines (58 loc) · 1.94 KB
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
package exercise_array;
import static java.lang.Integer.*;
import static java.lang.String.*;
import static java.lang.System.*;
import static yan_service.YANConstant.*;
import static yan_service.YANService.*;
/**
* Tóm tắt: Nhập 10 số tự nhiên và tìm các cặp phần tử đối xứng có cùng giá trị trong mảng.
*/
public class ArrayExercise {
public static void main(String[] args) {
// Tiêu đề chương trình
out.println(BLUE_BOLD);
printlnAdv("Array Exercise");
// Chạy nội dung chính
run();
}
// Hằng số và trạng thái dùng trong bài
private static final int N_MAX = 10;
// Luồng xử lý chính
private static void run() {
// Nhập dữ liệu
out.println();
var ns = new int[N_MAX];
for (var i = 0; i < N_MAX; i++) {
printAdv(GREEN, format("Nhập số tự nhiên thứ %d: ", i + 1), RESET);
ns[i] = numLimit(0, MAX_VALUE);
}
// In kết quả
out.print(YELLOW);
checkMirror(ns);
out.println();
// Hỏi người dùng có tiếp tục chạy lại không
checkOut();
}
// Tìm các cặp đối xứng
private static void checkMirror(int... args) {
// Duyệt các cặp phần tử đối xứng
var isSuccess = false;
var max = args.length;
for (var i = 0; i < max / 2; i++) {
if (args[i] == args[max - 1 - i]) {
isSuccess = true;
printlnAdv(format("Số %d đối xứng ở cặp vị trí %d và %d.", args[i], i + 1, max - i));
}
}
// In thông báo khi không có kết quả
if (!isSuccess) {
printlnAdv("Không có cặp số đối xứng nào.");
}
}
// Kiểm tra nhu cầu chạy lại
private static void checkOut() {
if (credit() == 1) {
run();
}
}
}