给定一个长度为L的字符串S ,其中L是一个完全平方数,任务是检查给定的字符串满足以下条件:
- 将字符串的字符按行方式插入维度为√L x √L 的方阵A[][]中。
- 用0 s 初始化另一个矩阵M[][] 。用1填充左对角线。现在,1只存在于左边对角线,填补其相应的含有1秒右对角线。
- 现在,检查是否在矩阵中的所有索引包含1 M [] [],包含A [] []相同的字符。
如果条件满足,打印“Yes”。否则,打印“否” 。
例子:
Input: S = ”abacdaeaafaghaia”
Output: Yes
Explanation:
Input: S = ”abacdaeabfaghaia”
Output: No
方法:思想是遍历矩阵A[][] ,其中它在矩阵M[][]中的对应字符为1 。请按照以下步骤解决问题:
- 计算矩阵的维度为N = √L 。
- 通过访问每个单元格A[i][i]其中1<= i<= N迭代左对角线。
- 对于单元格A[i][i]处左对角线的每个元素,用i初始化变量x和y ,并通过访问字符S[x*N + y]和S[y*N + x遍历其对应的右对角线]并且每次将x减1并每次将y增加1以沿着右对角线上的下一个单元格移动,而x不小于0并且y小于N 。
- 如果在上述步骤中发现所有字符都相同,则打印“Yes” 。否则,如果发现任何不匹配,则打印“否” 。
下面是上述方法的实现:
C++
// C++ program for the above approach
#include
using namespace std;
// Function to check if given string
// satisfies the given conditions
void isValid(string s)
{
// Dimensions
int n = sqrt(s.length());
char check = s[0];
// Left diagonal
for (int i = 0; i < n; i++) {
int x = i, y = i;
// Right diagonal
while (x >= 0 && y < n) {
if (s[(n * x) + y] != check
|| s[(n * y) + x] != check) {
// Conditions not satisfied
cout << "No" << endl;
return;
}
x--;
y++;
}
}
// Print Yes
cout << "Yes" << endl;
}
// Driver Code
int main()
{
// Given String
string str = "abacdaeaafaghaia";
// Function call
isValid(str);
return 0;
}
Java
// Java program for the above approach
import java.util.*;
class GFG{
// Function to check if given string
// satisfies the given conditions
static void isValid(String s)
{
// Dimensions
int n = (int)Math.sqrt(s.length());
char check = s.charAt(0);
// Left diagonal
for(int i = 0; i < n; i++)
{
int x = i, y = i;
// Right diagonal
while (x >= 0 && y < n)
{
if (s.charAt((n * x) + y) != check ||
s.charAt((n * y) + x) != check)
{
// Conditions not satisfied
System.out.print("No");
return;
}
x--;
y++;
}
}
// Print Yes
System.out.print("Yes");
}
// Driver Code
public static void main(String[] args)
{
// Given String
String str = "abacdaeaafaghaia";
// Function call
isValid(str);
}
}
// This code is contributed by code_hunt
Python3
# Python3 program for the above approach
import math
# Function to check if given string
# satisfies the given conditions
def isValid(s):
# Dimensions
n = int(math.sqrt(len(s)))
check = s[0]
# Left diagonal
for i in range(n):
x = i
y = i
# Right diagonal
while (x >= 0 and y < n):
if (s[n * x + y] != check or
s[n * x + x] != check):
# Conditions not satisfied
print("No")
return
x -= 1
y += 1
# Print Yes
print("Yes")
# Driver Code
# Given String
str = "abacdaeaafaghaia"
# Function call
isValid(str)
# This code is contributed by avanitrachhadiya2155
C#
// C# program for the above approach
using System;
class GFG{
// Function to check if given string
// satisfies the given conditions
static void isValid(string s)
{
// Dimensions
int n = (int)Math.Sqrt(s.Length);
char check = s[0];
// Left diagonal
for(int i = 0; i < n; i++)
{
int x = i, y = i;
// Right diagonal
while (x >= 0 && y < n)
{
if (s[(n * x) + y] != check ||
s[(n * y) + x] != check)
{
// Conditions not satisfied
Console.Write("No");
return;
}
x--;
y++;
}
}
// Print Yes
Console.Write("Yes");
}
// Driver code
public static void Main()
{
// Given String
string str = "abacdaeaafaghaia";
// Function call
isValid(str);
}
}
// This code is contributed by sanjoy_62
Javascript
输出:
Yes
时间复杂度: O(L) 其中L是给定字符串的长度。
辅助空间: O(L)
如果您想与行业专家一起参加直播课程,请参阅Geeks Classes Live