import java.util.Scanner;
import java.util.Arrays;
public class Main {
static int getMax(int[] arr, int n) {
int maxVal = arr[0];
for (int i = 1; i < n; i++) {
if (arr[i] > maxVal) {
maxVal = arr[i];
}
}
return maxVal;
}
public static void countingSort(int[] arr, int n, int exp) {
int[] output = new int[n];
int[] count = new int[10];
for (int i = 0; i < n; i++) {
count[(arr[i] / exp) % 10]++;
}
for (int i = 1; i < 10; i++) {
count[i] += count[i - 1];
}
for (int i = n - 1; i >= 0; i--) {
output[count[(arr[i] / exp) % 10] - 1] = arr[i];
count[(arr[i] / exp) % 10]--;
}
for (int i = 0; i < n; i++) {
arr[i] = output[i];
}
}
public static void radixSort(int[] arr, int n) {
int maxVal = getMax(arr, n);
for (int exp = 1; maxVal / exp > 0; exp *= 10) {
countingSort(arr, n, exp);
}
}
public static void main
(String[] args
) { Scanner scanner
= new Scanner
(System.
in); System.
out.
print("Enter the number of elements (n): "); if (!scanner.hasNextInt()) {
System.
out.
println("Invalid input for array size."); scanner.close();
return;
}
int n = scanner.nextInt();
if (n <= 0) {
System.
out.
println("Array size must be positive."); scanner.close();
return;
}
int[] arr = new int[n];
System.
out.
println("Enter " + n
+ " non-negative integers:"); for (int i = 0; i < n; i++) {
if (!scanner.hasNextInt()) {
System.
out.
println("Fewer than " + n
+ " integers provided. Stopping."); scanner.close();
return;
}
arr[i] = scanner.nextInt();
}
scanner.close();
radixSort(arr, n);
System.
out.
print("Sorted Array: "); for (int i = 0; i < n; i++) {
System.
out.
print(arr
[i
] + " "); }
}
}
aW1wb3J0IGphdmEudXRpbC5TY2FubmVyOwppbXBvcnQgamF2YS51dGlsLkFycmF5czsKCnB1YmxpYyBjbGFzcyBNYWluIHsKCiAgICBzdGF0aWMgaW50IGdldE1heChpbnRbXSBhcnIsIGludCBuKSB7CiAgICAgICAgaW50IG1heFZhbCA9IGFyclswXTsKICAgICAgICBmb3IgKGludCBpID0gMTsgaSA8IG47IGkrKykgewogICAgICAgICAgICBpZiAoYXJyW2ldID4gbWF4VmFsKSB7CiAgICAgICAgICAgICAgICBtYXhWYWwgPSBhcnJbaV07CiAgICAgICAgICAgIH0KICAgICAgICB9CiAgICAgICAgcmV0dXJuIG1heFZhbDsKICAgIH0KCiAgICBwdWJsaWMgc3RhdGljIHZvaWQgY291bnRpbmdTb3J0KGludFtdIGFyciwgaW50IG4sIGludCBleHApIHsKICAgICAgICBpbnRbXSBvdXRwdXQgPSBuZXcgaW50W25dOwogICAgICAgIGludFtdIGNvdW50ID0gbmV3IGludFsxMF07CiAgICAgICAgCiAgICAgICAgQXJyYXlzLmZpbGwoY291bnQsIDApOwoKICAgICAgICBmb3IgKGludCBpID0gMDsgaSA8IG47IGkrKykgewogICAgICAgICAgICBjb3VudFsoYXJyW2ldIC8gZXhwKSAlIDEwXSsrOwogICAgICAgIH0KCiAgICAgICAgZm9yIChpbnQgaSA9IDE7IGkgPCAxMDsgaSsrKSB7CiAgICAgICAgICAgIGNvdW50W2ldICs9IGNvdW50W2kgLSAxXTsKICAgICAgICB9CgogICAgICAgIGZvciAoaW50IGkgPSBuIC0gMTsgaSA+PSAwOyBpLS0pIHsKICAgICAgICAgICAgb3V0cHV0W2NvdW50WyhhcnJbaV0gLyBleHApICUgMTBdIC0gMV0gPSBhcnJbaV07CiAgICAgICAgICAgIGNvdW50WyhhcnJbaV0gLyBleHApICUgMTBdLS07CiAgICAgICAgfQoKICAgICAgICBmb3IgKGludCBpID0gMDsgaSA8IG47IGkrKykgewogICAgICAgICAgICBhcnJbaV0gPSBvdXRwdXRbaV07CiAgICAgICAgfQogICAgfQoKICAgIHB1YmxpYyBzdGF0aWMgdm9pZCByYWRpeFNvcnQoaW50W10gYXJyLCBpbnQgbikgewogICAgICAgIGludCBtYXhWYWwgPSBnZXRNYXgoYXJyLCBuKTsKCiAgICAgICAgZm9yIChpbnQgZXhwID0gMTsgbWF4VmFsIC8gZXhwID4gMDsgZXhwICo9IDEwKSB7CiAgICAgICAgICAgIGNvdW50aW5nU29ydChhcnIsIG4sIGV4cCk7CiAgICAgICAgfQogICAgfQoKICAgIHB1YmxpYyBzdGF0aWMgdm9pZCBtYWluKFN0cmluZ1tdIGFyZ3MpIHsKICAgICAgICBTY2FubmVyIHNjYW5uZXIgPSBuZXcgU2Nhbm5lcihTeXN0ZW0uaW4pOwogICAgICAgIFN5c3RlbS5vdXQucHJpbnQoIkVudGVyIHRoZSBudW1iZXIgb2YgZWxlbWVudHMgKG4pOiAiKTsKICAgICAgICBpZiAoIXNjYW5uZXIuaGFzTmV4dEludCgpKSB7CiAgICAgICAgICAgIFN5c3RlbS5vdXQucHJpbnRsbigiSW52YWxpZCBpbnB1dCBmb3IgYXJyYXkgc2l6ZS4iKTsKICAgICAgICAgICAgc2Nhbm5lci5jbG9zZSgpOwogICAgICAgICAgICByZXR1cm47CiAgICAgICAgfQogICAgICAgIGludCBuID0gc2Nhbm5lci5uZXh0SW50KCk7CiAgICAgICAgCiAgICAgICAgaWYgKG4gPD0gMCkgewogICAgICAgICAgICBTeXN0ZW0ub3V0LnByaW50bG4oIkFycmF5IHNpemUgbXVzdCBiZSBwb3NpdGl2ZS4iKTsKICAgICAgICAgICAgc2Nhbm5lci5jbG9zZSgpOwogICAgICAgICAgICByZXR1cm47CiAgICAgICAgfQogICAgICAgIAogICAgICAgIGludFtdIGFyciA9IG5ldyBpbnRbbl07CgogICAgICAgIFN5c3RlbS5vdXQucHJpbnRsbigiRW50ZXIgIiArIG4gKyAiIG5vbi1uZWdhdGl2ZSBpbnRlZ2VyczoiKTsKICAgICAgICBmb3IgKGludCBpID0gMDsgaSA8IG47IGkrKykgewogICAgICAgICAgICBpZiAoIXNjYW5uZXIuaGFzTmV4dEludCgpKSB7CiAgICAgICAgICAgICAgICBTeXN0ZW0ub3V0LnByaW50bG4oIkZld2VyIHRoYW4gIiArIG4gKyAiIGludGVnZXJzIHByb3ZpZGVkLiBTdG9wcGluZy4iKTsKICAgICAgICAgICAgICAgIHNjYW5uZXIuY2xvc2UoKTsKICAgICAgICAgICAgICAgIHJldHVybjsKICAgICAgICAgICAgfQogICAgICAgICAgICBhcnJbaV0gPSBzY2FubmVyLm5leHRJbnQoKTsKICAgICAgICB9CiAgICAgICAgc2Nhbm5lci5jbG9zZSgpOwoKICAgICAgICByYWRpeFNvcnQoYXJyLCBuKTsKCiAgICAgICAgU3lzdGVtLm91dC5wcmludCgiU29ydGVkIEFycmF5OiAiKTsKICAgICAgICBmb3IgKGludCBpID0gMDsgaSA8IG47IGkrKykgewogICAgICAgICAgICBTeXN0ZW0ub3V0LnByaW50KGFycltpXSArICIgIik7CiAgICAgICAgfQogICAgICAgIFN5c3RlbS5vdXQucHJpbnRsbigpOwogICAgfQp9