Table of Contents
ExampleExample
method one
algorithm
Example
Output
in conclusion
Home Backend Development C++ Checks whether all characters in a string can be made equal by increasing or decreasing

Checks whether all characters in a string can be made equal by increasing or decreasing

Sep 11, 2023 am 11:25 AM
String processing Characters are equal Increase or decrease operations

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;
}
Copy after login

Output

Yes
Copy after login

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!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Two Point Museum: All Exhibits And Where To Find Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Explain in simple terms: Detailed explanation of string escaping and anti-escaping in GO language Explain in simple terms: Detailed explanation of string escaping and anti-escaping in GO language Apr 07, 2024 am 10:39 AM

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.

Errors that may occur in PHP string processing and how to fix them Errors that may occur in PHP string processing and how to fix them May 11, 2023 pm 05:21 PM

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

Best practices for converting strings to floating point numbers in PHP Best practices for converting strings to floating point numbers in PHP Mar 28, 2024 am 08:18 AM

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

Master regular expressions and string processing in Go language Master regular expressions and string processing in Go language Nov 30, 2023 am 09:54 AM

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.

Master the secrets of string escaping and anti-escaping in GO language Master the secrets of string escaping and anti-escaping in GO language Apr 07, 2024 pm 04:33 PM

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 string processing: detailed explanation of how to remove all spaces PHP string processing: detailed explanation of how to remove all spaces Mar 23, 2024 pm 06:51 PM

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

How to remove specific characters from a string in PHP using regular expressions How to remove specific characters from a string in PHP using regular expressions Jun 22, 2023 pm 03:46 PM

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

What are the 7 PHP string processing functions? What are the 7 PHP string processing functions? Sep 18, 2023 pm 02:14 PM

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.

See all articles