3011. Find if Array Can Be Sorted
Difficulty: Medium
Topics: Array, Bit Manipulation, Sorting
You are given a 0-indexed array of positive integers nums.
In one operation, you can swap any two adjacent elements if they have the same number of set bits1. You are allowed to do this operation any number of times (including zero).
Return true if you can sort the array, else return false.
Example 1:
- Input: nums = [8,4,2,30,15]
- Output: true
-
Explanation: Let's look at the binary representation of every element. The numbers 2, 4, and 8 have one set bit each with binary representation "10", "100", and "1000" respectively. The numbers 15 and 30 have four set bits each with binary representation "1111" and "11110".
We can sort the array using 4 operations:
- Swap nums[0] with nums[1]. This operation is valid because 8 and 4 have one set bit each. The array becomes [4,8,2,30,15].
- Swap nums[1] with nums[2]. This operation is valid because 8 and 2 have one set bit each. The array becomes [4,2,8,30,15].
- Swap nums[0] with nums[1]. This operation is valid because 4 and 2 have one set bit each. The array becomes [2,4,8,30,15].
- Swap nums[3] with nums[4]. This operation is valid because 30 and 15 have four set bits each. The array becomes [2,4,8,15,30].
- The array has become sorted, hence we return true.
- Note that there may be other sequences of operations which also sort the array.
Example 2:
- Input: nums = [1,2,3,4,5]
- Output: true
- Explanation: The array is already sorted, hence we return true.
Example 3:
- Input: nums = [3,16,8,4,2]
- Output: false
- Explanation: It can be shown that it is not possible to sort the input array using any number of operations.
Example 4:
- Input: nums = [75,34,30]
- Output: false
- Explanation: It can be shown that it is not possible to sort the input array using any number of operations.
Constraints:
- 1
- 1 8
Hint:
- Split the array into segments. Each segment contains consecutive elements with the same number of set bits.
- From left to right, the previous segment’s largest element should be smaller than the current segment’s smallest element.
Solution:
We need to determine if the array can be sorted by only swapping adjacent elements that have the same number of set bits in their binary representation. Here’s the plan:
Solution Steps:
Key Observation: The operation allows us to swap adjacent elements only if they have the same number of set bits. This restricts swapping across elements with different numbers of set bits.
-
Plan:
- Group elements by the number of set bits in their binary representation.
- Sort each group individually, since within a group, elements can be rearranged by swaps.
- After sorting each group, merge the sorted groups back together.
- Check if this merged array is sorted. If it is, then sorting the array using the allowed operations is possible.
-
Steps:
- Count the set bits in each number and group numbers with the same set bit count.
- Sort each group individually.
- Reconstruct the array from these sorted groups and verify if the result is sorted.
Let's implement this solution in PHP: 3011. Find if Array Can Be Sorted
<?php /** * Helper function to count set bits in a number * * @param $n * @return int */ function countSetBits($n) { ... ... ... /** * go to ./solution.php */ } /** * @param Integer[] $nums * @return Boolean */ function canSortArray($nums) { ... ... ... /** * go to ./solution.php */ } // Test cases $nums1 = [8, 4, 2, 30, 15]; $nums2 = [1, 2, 3, 4, 5]; $nums3 = [3, 16, 8, 4, 2]; $nums4 = [75, 34, 30]; echo canBeSorted($nums1) ? 'true' : 'false'; // Expected output: true echo "\n"; echo canBeSorted($nums2) ? 'true' : 'false'; // Expected output: true echo "\n"; echo canBeSorted($nums3) ? 'true' : 'false'; // Expected output: false echo "\n"; echo canBeSorted($nums4) ? 'true' : 'false'; // Expected output: false ?>
Explanation:
- countSetBits Function: Counts the number of set bits in a number using bitwise operations.
- Grouping Elements: bitGroups is an associative array where each key represents the set bit count, and each value is an array of numbers with that many set bits.
-
Sorting and Rebuilding:
- We iterate over nums to group elements by their set bit count.
- We sort each group independently.
- We then reconstruct the array by inserting each sorted group element in its original order.
- Finally, we check if the reconstructed array is sorted in non-decreasing order. If it is, return true; otherwise, return false.
Final Comparison: Compare the rebuilt array with a fully sorted version of nums. If they match, return true; otherwise, return false.
Complexity Analysis
- Time Complexity: O(n log n) due to the sorting within each group and the final comparison.
- Space Complexity: O(n) for storing the bit groups.
This solution ensures that we only swap adjacent elements with the same set bit count, achieving a sorted order if possible.
Contact Links
If you found this series helpful, please consider giving the repository a star on GitHub or sharing the post on your favorite social networks ?. Your support would mean a lot to me!
If you want more helpful content like this, feel free to follow me:
- GitHub
-
Set Bit A set bit refers to a bit in the binary representation of a number that has a value of 1. ↩
The above is the detailed content of Find if Array Can Be Sorted. For more information, please follow other related articles on the PHP Chinese website!

Laravel simplifies handling temporary session data using its intuitive flash methods. This is perfect for displaying brief messages, alerts, or notifications within your application. Data persists only for the subsequent request by default: $request-

The PHP Client URL (cURL) extension is a powerful tool for developers, enabling seamless interaction with remote servers and REST APIs. By leveraging libcurl, a well-respected multi-protocol file transfer library, PHP cURL facilitates efficient execution of various network protocols, including HTTP, HTTPS, and FTP. This extension offers granular control over HTTP requests, supports multiple concurrent operations, and provides built-in security features.

Laravel provides concise HTTP response simulation syntax, simplifying HTTP interaction testing. This approach significantly reduces code redundancy while making your test simulation more intuitive. The basic implementation provides a variety of response type shortcuts: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

PHP logging is essential for monitoring and debugging web applications, as well as capturing critical events, errors, and runtime behavior. It provides valuable insights into system performance, helps identify issues, and supports faster troubleshoot

Do you want to provide real-time, instant solutions to your customers' most pressing problems? Live chat lets you have real-time conversations with customers and resolve their problems instantly. It allows you to provide faster service to your custom

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

The article discusses adding custom functionality to frameworks, focusing on understanding architecture, identifying extension points, and best practices for integration and debugging.

Alipay PHP...


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.