排列对称串

简介: 排列对称串

Description:很多字串,有些是对称的,有些是不对称的,请将那些对称的字事按从小到大的顺序输出,字事先以长度论大小,如果长度相同,再以ASCI码值为大小标准

Input.输入数据中含有一些字串(1≤串长≤256)。

#include <iostream>
#include <vector>
#include <algorithm>
#include <string>
using namespace std;
class String {
public:
    String(const string& s) : str_(s) {}  // 判断字符串是否对称
    bool pd() const {
        int left = 0, right = str_.size() - 1;
        while (left < right) {
            if (str_[left] != str_[right]) {
                return false;
            }
            ++left;
            --right;
        }
        return true;
    }
    bool operator<(const String& other) const {
        if (str_.size() != other.str_.size()) {
            return str_.size() < other.str_.size();  }
        return str_ < other.str_;}
    const string& Get() const {
        return str_;
    }
private:
    string str_;
};
int main() {
    vector<String> fn;
    string s;
    while (cin >> s) { fn.push_back(String(s)); }
    vector<String> ff;
    copy_if(fn.begin(), fn.end(),
        back_inserter(ff),
        [](const String& ss) { return ss.pd(); });
   sort(ff.begin(), ff.end());
    for (const auto& ss : ff) {
       cout << ss.Get() << endl;
    }
    return 0;
}

这种情况下,无法实现回车两次直接输出结果,借助Ctrl+z两次输出结果,跳出循环

while (cin >> s) { fn.push_back(String(s)); }

改为

while (getline(cin, s) && !s.empty()) {
   fn.push_back(String(s));
}

#include <iostream>
#include <vector>
#include <algorithm>
#include <string>
using namespace std;
class String {
public:
    String(const string& s) : str_(s) {}  // 判断字符串是否对称
    bool pd() const {
        int left = 0, right = str_.size() - 1;
        while (left < right) {
            if (str_[left] != str_[right]) {
                return false;
            }
            ++left;
            --right;
        }
        return true;
    }
    bool operator<(const String& other) const {
        if (str_.size() != other.str_.size()) {
            return str_.size() < other.str_.size();  }
        return str_ < other.str_;}
    const string& Get() const {
        return str_;
    }
private:
    string str_;
};
int main() {
    vector<String> fn;
    string s;
    while (getline(cin, s) && !s.empty()) {
    fn.push_back(String(s));
}
    vector<String> ff;
    copy_if(fn.begin(), fn.end(),
        back_inserter(ff),
        [](const String& ss) { return ss.pd(); });
   sort(ff.begin(), ff.end());
    for (const auto& ss : ff) {
       cout << ss.Get() << endl;
    }
    return 0;
}

这个时候可以直接借助两次回车将结果输出

思路如下:

  1. 定义了一个名为String的类,构造函数接受一个string类型的参数s,初始化私有成员变量str_。类中包含了三个成员函数:
  • pd():检查字符串是否对称(即回文串)。通过两个指针leftright分别从字符串两端开始向中间移动,如果在移动过程中遇到不相等的字符,则返回false,否则遍历完成后返回true,表示字符串是对称的。
  • operator<:重载小于运算符,用于在排序时比较两个String对象。首先比较字符串长度,长度短的更小;长度相同时,按照字典序比较字符串内容。
  • Get():获取封装的字符串。
  1. main()函数流程:
  • 初始化一个vector容器fn用于存储用户输入的字符串。
  • 通过循环从标准输入(通常是键盘)读取字符串s,并将每个字符串实例化为String对象后推入fn容器中。
  • 使用copy_if算法将满足对称条件(即pd()返回true)的String对象复制到新的vector容器ff中。
  • ff容器中的String对象进行排序。
  • 遍历排序后的ff容器,输出每个String对象所封装的字符串内容。


目录
相关文章
|
分布式计算 Hadoop Java
hadoop伪分布式搭建(超详细)
hadoop伪分布式搭建(超详细)
2390 0
|
10月前
|
人工智能 自然语言处理 供应链
《AI时代,别让数字鸿沟隔断未来》
在AI时代,数字鸿沟已成为新的“分水岭”,表现为不同群体在获取和使用信息通信技术(ICT)方面的差距。全球范围内,发达国家凭借雄厚实力领跑AI领域,而发展中国家因网络覆盖率低、缺乏人才和资源而落后。国内城乡之间也存在显著差距,城市居民能便捷使用AI工具,农村地区则网络基础设施滞后,难以享受AI带来的便利。此外,不同年龄段对AI的接受度也存在差异,年轻人热衷尝试新技术,老年人则面临操作困难。 数字鸿沟加剧了社会不平等,影响就业、收入和职业发展机会,限制了个人和地区的经济发展潜力。为缩小这一差距,政府应加大数字基础设施建设投入,特别是在农村和偏远地区;教育机构需将AI纳入课程体系.
341 0
《AI时代,别让数字鸿沟隔断未来》
QGS
|
SQL 弹性计算 Java
手搭手入门Spring boot+Mybatis+达梦数据库(国产数据库)
手搭手入门Spring boot+Mybatis+达梦数据库(国产数据库)
QGS
1413 0
|
Linux
centos7 虚拟机修改IP地址
centos7 虚拟机修改IP地址
363 0
|
安全 Linux 网络安全
【操作系统】实验一 Linux操作系统安装
【操作系统】实验一 Linux操作系统安装
371 3
|
NoSQL Ubuntu Linux
【操作系统】实验三 编译 Linux 内核
【操作系统】实验三 编译 Linux 内核
587 1
【操作系统】实验九 写一个设备驱动程序
【操作系统】实验九 写一个设备驱动程序
382 1
|
存储 Linux 网络安全
【操作系统】实验二 Proc文件系统
【操作系统】实验二 Proc文件系统
372 1
|
分布式计算 数据可视化 Hadoop
【分布式计算框架】HDFS常用操作及编程实践
【分布式计算框架】HDFS常用操作及编程实践
645 1
|
存储 Ubuntu NoSQL
【CSAPP】DataLab
史上最全的CSAPP之DataLab实验讲解汇总(万字详解!超全面!超详细!)收藏这一篇就够了!!!这个精心制作的指南提供了CSAPP DataLab实验的全面解析,涵盖了数以万字计的详细讲解。从概念到实际实验步骤,这篇文章提供了无与伦比的指导,为学习者提供了宝贵的资源。如果您正在学习CSAPP或对计算机体系结构和编程感兴趣,这一份详尽的讲解将成为您不可或缺的参考资料。不仅提供了理论知识,还包含了实际实验和解决问题的技巧,确保您能够深入理解和掌握这一重要主题。
751 0
【CSAPP】DataLab