ধরুন আমাদের কাছে এইরকম আলফানিউমেরিক স্ট্রিংগুলির একটি অ্যারে আছে −
const arr = ['A1', 'A10', 'A11', 'A12', 'A3A', 'A3B', 'A3', 'A4', 'B10', 'B2', 'F1', '1', '2', 'F3'];
আমাদের একটি জাভাস্ক্রিপ্ট ফাংশন লিখতে হবে যেটি একটি অ্যারেতে একটি এবং একমাত্র আর্গুমেন্ট।
এবং ফাংশন এই অ্যারে ইনপ্লেস −
সাজাতে হবে- যে স্ট্রিংগুলিতে শুধুমাত্র সংখ্যা রয়েছে তা প্রথমে ক্রমবর্ধমান ক্রমে সাজানো উচিত।
- বর্ণমালা এবং সংখ্যার সংমিশ্রণ সম্বলিত স্ট্রিংগুলি প্রথমে বর্ণমালা অনুসারে এবং তারপর সংখ্যা অনুসারে ক্রমবর্ধমান ক্রমে সাজাতে হবে।
অতএব, আউটপুট −
এর মত হওয়া উচিতconst output = ['1', '2', 'A1', 'A2', 'A3', 'A3A', 'A3B', 'A4', 'A10', 'A11', 'A12', 'B2', 'B10', 'F1', 'F3'];
উদাহরণ
const arr = ['A1', 'A10', 'A11', 'A12', 'A3A', 'A3B', 'A3', 'A4', 'B10', 'B2', 'F1', '1', '2', 'F3'];
const alphaNumericSort = (arr = []) => {
const sorter = (a, b) => {
const isNumber = (v) => (+v).toString() === v;
const aPart = a.match(/\d+|\D+/g);
const bPart = b.match(/\d+|\D+/g);
let i = 0; let len = Math.min(aPart.length, bPart.length);
while (i < len && aPart[i] === bPart[i]) { i++; };
if (i === len) {
return aPart.length - bPart.length;
};
if (isNumber(aPart[i]) && isNumber(bPart[i])) {
return aPart[i] - bPart[i];
};
return aPart[i].localeCompare(bPart[i]); };
arr.sort(sorter);
};
alphaNumericSort(arr);
console.log(arr); আউটপুট
এবং কনসোলে আউটপুট হবে −
[ '1', '2', 'A1', 'A3', 'A3A', 'A3B', 'A4', 'A10', 'A11', 'A12', 'B2', 'B10', 'F1', 'F3' ]