zcmu b题题解

2163: 项链

Time Limit: 1 Sec  Memory Limit: 128 MB
Submit: 114  Solved: 48
[Submit][Status][Web Board]

Description

强迫症非常麻烦,尤其是买东西的时候。冠璐女神的生日快到了,某强迫症要送一条项链送给她,重点是,这条项链要对称,这条项链要对称,这条项链要对称。(很重要所以说三遍)
项链都是环状的(废话...),每条项链上有颜色不同的珍珠,用小写字母 a−z 代表不同的颜色。一条项链是对称的,是指从项链的某个位置开始,两个方向看过去是一样的(珍珠的颜色一样)。
比方说,如图所示的项链(第一个输入样例),从箭头位置开始看,无论是顺时针还是逆时针,看到的都是ababbaba,因此这条项链是对称的。
有的项链非常长,很难看出它们的对称性。你能快速地判断哪些项链是对称的吗?

 

 

Input

第一行有一个整数N,表示一共有N条项链。
接下来N行,每行一个由小写字母组成的字符串,代表项链上珍珠的颜色,可能从项链的任意位置开始。

 

Output

输出N行,如果项链是对称的,输出YES,否则输出NO。

 

Sample Input

3 abbabaab abab abcdefg

Sample Output

YES YES NO

HINT

 

1≤N≤5,项链长度≤10^5

 

题目大意:

给你一串字符串,头尾相连,从某个点切开,是否能有正序和反序一样的字符串。

思路:

在看过大佬的三行代码后,悟出的。这个题难点在于不知道从哪个点切开可以得到符合条件的字符串,从第一个位置开始一个个切开再判断太费时间。

所以,我们应该把字符串复制一遍贴到原字符串后面,这样所有的不同切法的字符串都变成了这个新串的子串了。

接着再将整个字符串反转变成反序,判断反转后的字符串中是否有与原字符串相同的子串就行了。

AC代码:

#include<iostream>
#include<cstdio>
#include<string>
#include<cstring>
#include<algorithm>
#define per(a,n)for(int i=a;i<n;i++)
#define rep(a,n) for(int i=n-1;i>=a;i--)
typedef long long ll;
using namespace std;
//题目大意:一串字符串,头尾相连,从某个点切开,正序和反序一样;
int main()
{
int t;
cin>>t;
string xl,s;
while(t--)
{
    cin>>xl;
    s=xl+xl;//将字符串复制一遍,这样不论从哪个点开始切入的字符串都有了
    reverse(s.begin(),s.end());//将字符串反转
    if(strstr(s.c_str(),xl.c_str()))//判断反转后的s中是否有与原字符串相同的子串;
    {
        cout<<"YES\n";
    }
    else
        cout<<"NO\n";
}

    return 0;
}

 

CH341A编程器是一款广泛应用的通用编程设备,尤其在电子工程和嵌入式系统开发领域中,它被用来烧录各种类型的微控制器、存储器和其他IC芯片。这款编程器的最新版本为1.3,它的一个显著特点是增加了对25Q256等32M芯片的支持。 25Q256是一种串行EEPROM(电可擦可编程只读存储器)芯片,通常用于存储程序代码、配置数据或其他非易失性信息。32M在这里指的是存储容量,即该芯片可以存储32兆位(Mbit)的数据,换算成字节数就是4MB。这种大容量的存储器在许多嵌入式系统中都有应用,例如汽车电子、工业控制、消费电子设备等。 CH341A编程器的1.3版更新,意味着它可以与更多的芯片型号兼容,特别是针对32M容量的芯片进行了优化,提高了编程效率和稳定性。26系列芯片通常指的是Microchip公司的25系列SPI(串行外围接口)EEPROM产品线,这些芯片广泛应用于各种需要小体积、低功耗和非易失性存储的应用场景。 全功能版的CH341A编程器不仅支持25Q256,还支持其他大容量芯片,这意味着它具有广泛的兼容性,能够满足不同项目的需求。这包括但不限于微控制器、EPROM、EEPROM、闪存、逻辑门电路等多种类型芯片的编程。 使用CH341A编程器进行编程操作时,首先需要将设备通过USB连接到计算机,然后安装相应的驱动程序和编程软件。在本例中,压缩包中的"CH341A_1.30"很可能是编程软件的安装程序。安装后,用户可以通过软件界面选择需要编程的芯片类型,加载待烧录的固件或数据,然后执行编程操作。编程过程中需要注意的是,确保正确设置芯片的电压、时钟频率等参数,以防止损坏芯片。 CH341A编程器1.3版是面向电子爱好者和专业工程师的一款实用工具,其强大的兼容性和易用性使其在众多编程器中脱颖而出。对于需要处理25Q256等32M芯片的项目,或者26系列芯片的编程工作,CH341A编程器是理想的选择。通过持续的软件更新和升级,它保持了与现代电子技术同步,确保用户能方便地对各种芯片进行编程和调试。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值