C++ program to rearrange array in max-min form
We get an array of integers, which can be arranged in a sorted/unsorted manner. The task is to first sort the array (if the values are not sorted) and then arrange the array in such a way that the first element of the array is the maximum value, the second element is the minimum value, and the third element is the array. The second maximum, the fourth will be the second minimum, and so on.
Let’s look at various input and output scenarios for this situation -
Input − int arr[] = {7, 5, 2, 3, 4, 9, 10, 5 }
Output− Array before sorting: 2 3 4 5 5 7 9 10 Rearrange the array in max-min form as: 10 2 9 3 7 4 5 5
Explanation− We get an array of integer type containing the values {7, 5, 2, 3, 4, 9, 10, 5}. First, we sort an array, it will be {2 3 4 5 5 7 9 10}. Second, arrange the largest element at arr[0] (i.e. 10), then arrange the smallest element at arr[1] (i.e. 2), then arrange the second largest element at arr[2] (i.e. 9), and so on analogy. The final result array will be 10 2 9 3 7 4 5 5
Input− int arr[] = {2, 4, 1, 6, 7}
Output− Array before sorting: 1, 2, 4, 6, 7 Rearrange the array in max-min form as: 7, 1, 6, 2, 4
Explanation− We get an array of integer type containing the values {2, 4, 1, 6 , 7}. First we sort an array, the result is {1,2,4,6,7}. Secondly, arrange the largest element at arr[0], that is 7 then the smallest element at arr[1] which is 1 then the second largest element at arr[2] which is 6 and so on. The final array will be 7, 1, 6, 2, 4
The method used in the following program is as follows
Input an array of integer type elements and calculate the value of the array size. Call the C STL's sort method by passing arr[] and the array size as arguments to the function.
Print the array before sorting and call the function Rearr_Max_Min(arr, size)
-
Inside the function Rearr_Max_Min(arr, size)
Declare one variable as max and set it to size - 1, and set another variable as min and set it to 0. Declare the variable as max_val and set it to arr[size - 1] 1.
Start looping FOR from i to 0 until i is less than size. Inside the loop, check IF i % 2 = 0, then set arr[i] to arr[i] (arr[max] % max_val) * max_val and decrement the maximum value by 1.
Otherwise, set arr[i] to arr[i] (arr[min] % max_val) * max_val and increase min by 1.
Start looping FOR from i to 0 until i is less than size. Inside the loop, set arr[i] to arr[i] / max_val
#include <bits/stdc++.h>
using namespace std;
void Rearr_Max_Min(int arr[], int size){
int max = size - 1;
int min = 0;
int max_val = arr[size - 1] + 1;
for (int i = 0; i < size; i++){
if (i % 2 == 0){
arr[i] += (arr[max] % max_val) * max_val;
max--;
}
else{
arr[i] += (arr[min] % max_val) * max_val;
min++;
}
}
for(int i = 0; i < size; i++){
arr[i] = arr[i] / max_val;
}
}
int main(){
//input an array
int arr[] = {7, 5, 2, 3, 4, 9, 10, 5 };
int size = sizeof(arr) / sizeof(arr[0]);
//sort an array
sort(arr, arr + size);
//print the original Array after sorting
cout<<"Array before Arrangement: ";
for (int i = 0; i < size; i++){
cout << arr[i] << " ";
}
//calling the function to rearrange the array
Rearr_Max_Min(arr, size);
//print the array after rearranging the values
cout<<"\nRearrangement of an array in maximum minimum form is: ";
for(int i = 0; i < size; i++){
cout<< arr[i] << " ";
}
return 0;
}
Output If we run the above code it will generate the following output Array before Arrangement: 2 3 4 5 5 7 9 10 Rearrangement of an array in maximum minimum form is: 10 2 9 3 7 4 5 5
The above is the detailed content of C++ program to rearrange array in max-min form. For more information, please follow other related articles on the PHP Chinese website!

C In interviews, smart pointers are the key tools that help manage memory and reduce memory leaks. 1) std::unique_ptr provides exclusive ownership to ensure that resources are automatically released. 2) std::shared_ptr is used for shared ownership and is suitable for multi-reference scenarios. 3) std::weak_ptr can avoid circular references and ensure secure resource management.

The future of C will focus on parallel computing, security, modularization and AI/machine learning: 1) Parallel computing will be enhanced through features such as coroutines; 2) Security will be improved through stricter type checking and memory management mechanisms; 3) Modulation will simplify code organization and compilation; 4) AI and machine learning will prompt C to adapt to new needs, such as numerical computing and GPU programming support.

C is still important in modern programming because of its efficient, flexible and powerful nature. 1)C supports object-oriented programming, suitable for system programming, game development and embedded systems. 2) Polymorphism is the highlight of C, allowing the call to derived class methods through base class pointers or references to enhance the flexibility and scalability of the code.

The performance differences between C# and C are mainly reflected in execution speed and resource management: 1) C usually performs better in numerical calculations and string operations because it is closer to hardware and has no additional overhead such as garbage collection; 2) C# is more concise in multi-threaded programming, but its performance is slightly inferior to C; 3) Which language to choose should be determined based on project requirements and team technology stack.

C isnotdying;it'sevolving.1)C remainsrelevantduetoitsversatilityandefficiencyinperformance-criticalapplications.2)Thelanguageiscontinuouslyupdated,withC 20introducingfeatureslikemodulesandcoroutinestoimproveusabilityandperformance.3)Despitechallen

C is widely used and important in the modern world. 1) In game development, C is widely used for its high performance and polymorphism, such as UnrealEngine and Unity. 2) In financial trading systems, C's low latency and high throughput make it the first choice, suitable for high-frequency trading and real-time data analysis.

There are four commonly used XML libraries in C: TinyXML-2, PugiXML, Xerces-C, and RapidXML. 1.TinyXML-2 is suitable for environments with limited resources, lightweight but limited functions. 2. PugiXML is fast and supports XPath query, suitable for complex XML structures. 3.Xerces-C is powerful, supports DOM and SAX resolution, and is suitable for complex processing. 4. RapidXML focuses on performance and parses extremely fast, but does not support XPath queries.

C interacts with XML through third-party libraries (such as TinyXML, Pugixml, Xerces-C). 1) Use the library to parse XML files and convert them into C-processable data structures. 2) When generating XML, convert the C data structure to XML format. 3) In practical applications, XML is often used for configuration files and data exchange to improve development efficiency.


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

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 English version
Recommended: Win version, supports code prompts!

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

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.

SublimeText3 Chinese version
Chinese version, very easy to use

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function
