


Checks whether all characters in a string can be made equal by increasing or decreasing
In this problem, we need to check whether all the characters of the string can be made equal by increasing and decreasing operations. We can get the weight of each character based on its ASCII value and check if the total weight can be used to make all characters equal.
Problem Statement – We are given a string str of length N containing lowercase alphabetic characters. We need to check if we can make all the characters in the string equal by selecting either of the two characters, increasing one character, and then decrementing the other character by 1. Prints "yes" if possible, otherwise prints "no".
ExampleExample
Input– str = ‘aedb
Output-str = ‘aedb
Explanation - ‘a’ can be increased by 2 and ‘e’ can be decreased by 2. At the same time, 'b' can be incremented by 1 and 'd' can be incremented by 1. Therefore, the resulting string can be 'cccc'.
Input– str = ‘abd’
Output-"No"
Explanation – We cannot make all characters of a string equal by increasing and decreasing operations
Enter-‘g’
Output - 'Yes'
Explanation – A string contains only a single character, so all string characters are already equal
method one
In this method, we will calculate the total character weight of the string. The weights of characters are defined as ‘a’ = 1, ‘b’ = 2, ‘c’ = 3, …, ‘z’ = 26. So if we divide the total weight by the length of the string, we can say that by increasing one character and decreasing another, we make all characters of the string equal.
algorithm
Define the "len" variable and use the size() method to store the size of the string.
Define the "totalWeight" variable to store the total weight of all characters of a given string
Get the weight of a specific character using the ASCII code of each character and add it to the "totalWeight" variable.
Returns true if the value of "totalWeight" is divisible by "len". Otherwise, returns false.
Example
#include <iostream> using namespace std; // function to check if all characters of a string can be made equal by incrementing or decrementing by 1 bool canMakeEqual(string str){ int len = str.size(); // store sum of ASCII values of characters int totalWeight = 0; // Iterate over the string for (int i = 0; i < len; i++){ // get the ASCII value of each character totalWeight += str[i] - 'a' + 1; } return (totalWeight % len == 0); } int main(){ string str = "aedb"; if (canMakeEqual(str)) cout << "Yes"; else cout << "No"; return 0; }
Output
Yes
Time complexity - O(N), since we iterate over the string.
Space complexity - O(1), because we use constant space.
in conclusion
We learned to check whether all characters of a string can be equal by increasing and decreasing the ASCII value of the character. We solve this problem in terms of "total weight". The user can also try to find the resulting string. To find the resulting string, find the ASCII value corresponding to (totalWeight/len) and add "len" characters to the given string.
The above is the detailed content of Checks whether all characters in a string can be made equal by increasing or decreasing. For more information, please follow other related articles on the PHP Chinese website!

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

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

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

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

Hot Topics

In Go language, string escape uses backslash (\`) plus special characters to represent special characters, such as newline character (\n). Anti-escaping uses backticks (\`) to remove escaped characters and restore their original characters, such as \n representing the actual newline character. Practical cases demonstrate the application of escaping, anti-escaping and anti-escaping in file reading.

PHP is a widely used dynamic programming language that has a wide range of applications, especially in the development of web applications. String processing is one of the most commonly used functions in PHP, but many times developers encounter various errors and problems when processing strings. In this article, we will explore several common problems you may encounter during PHP string processing and how to solve them. Character Encoding Issues When processing strings, a common issue is character encoding. There are many different character encodings, the most common of which is UT

Converting strings to floating point numbers in PHP is a common requirement during the development process. For example, the amount field read from the database is of string type and needs to be converted into floating point numbers for numerical calculations. In this article, we will introduce the best practices for converting strings to floating point numbers in PHP and give specific code examples. First of all, we need to make it clear that there are two main ways to convert strings to floating point numbers in PHP: using (float) type conversion or using (floatval) function. Below we will introduce these two

As a modern programming language, Go language provides powerful regular expressions and string processing functions, allowing developers to process string data more efficiently. It is very important for developers to master regular expressions and string processing in Go language. This article will introduce in detail the basic concepts and usage of regular expressions in Go language, and how to use Go language to process strings. 1. Regular expressions Regular expressions are a tool used to describe string patterns. They can easily implement operations such as string matching, search, and replacement.

String escaping uses backslashes to represent special characters as escape sequences, while unescaping returns escape sequences to actual characters. The Go language supports the following escape sequences: \n (line feed), \t (tab), \r (carriage return), \f (form feed), \a (alarm), \b (backspace) ), \v (vertical tab), in addition to the backslash itself, single quotes, and double quotes. Raw string literals are enclosed in backticks and no characters are escaped. Escape characters are useful in HTML code and JSON data to display or escape special characters.

PHP is a powerful programming language that is widely used in web development. In the process of web development, we often encounter situations where strings need to be processed, and removing spaces from strings is a common requirement. This article will introduce in detail how to remove all spaces from a string in PHP and provide specific code examples. 1. Use the str_replace function. The str_replace function is a commonly used string replacement function in PHP. It can replace a specified character with another character. By using this function, you can

In PHP, you can easily remove specific characters from a string using regular expressions. Regular expression is a powerful tool that helps us match and manipulate text based on specified patterns. In this article, we will introduce how to use regular expressions to remove specific characters from a string, and how to use the preg_replace function in PHP to achieve this goal. Using regular expressions to replace specific characters "." in regular expressions identifies any single character, we can use

The seven PHP string processing functions include strlen(), strpos(), substr(), str_replace(), strtolower(), strtoupper(), trim(), etc. Detailed introduction: 1. strlen(), used to obtain the length of a string; 2. strpos(), used to find a specific substring in a string and return the first occurrence position; 3. substr(), used to obtain Substring of string; 4. str_replace(), etc.
