LeetCode 249. Group Shifted Strings

Given a string, we can "shift" each of its letter to its successive letter, for example: "abc" -> "bcd". We can keep "shifting" which forms the sequence:

"abc" -> "bcd" -> ... -> "xyz"

Given a list of strings which contains only lowercase alphabets, group all strings that belong to the same shifting sequence.

For example, given: ["abc", "bcd", "acef", "xyz", "az", "ba", "a", "z"]
Return:

[
  ["abc","bcd","xyz"],
  ["az","ba"],
  ["acef"],
  ["a","z"]
]

#include <string>
#include <unordered_map>
#include <vector>
#include <algorithm>
#include <iostream>
using namespace std;

vector< vector<string> > groupStrings(vector<string>& strings) {
  unordered_map<string, vector<string> > map;
  vector< vector< string> > res;
  for(auto str : strings) {
    string tmp = str;
    for(int i = tmp.size() - 1; i >= 0; --i) {
      tmp[i] = ('a' + (tmp[i] - tmp[0] + 26) % 26); // since it is group shifted.
    }
    map[tmp].push_back(str);
  }
  for(auto val : map) {
    sort(val.second.begin(), val.second.end());
    res.push_back(val.second);
  }
  return res;
}

int main(void) {
  vector<string> str{"abc", "bcd", "acef", "xyz", "az", "ba", "a", "z"};
  vector< vector<string> > res = groupStrings(str);
  for(int i = 0; i < res.size(); ++i) {
    for(int j = 0; j < res[i].size(); ++j) {
      cout << res[i][j] << " ";
    }
    cout << endl;
  }
}


基于Spring Cloud和CAS的单点登录系统是一个采用微服务架构的高可用认证授权平台,主要用于解决企业级应用中的统一身份认证和单点登录需求。该系统基于Java语言开发,采用Spring Boot和Spring Cloud作为核心框架,集成了CAS 5.1.x作为认证服务,实现了配置中心、监控平台和服务管理等功能模块,支持Docker容器化部署,确保系统的高可用性和可扩展性。 系统的主要功能包括:CAS认证服务,提供统一的用户登录、认证和授权机制;配置中心,实现配置信息的集中管理和动态更新;监控平台,实时监控系统运行状态和性能指标;服务管理,支持服务的注册、发现和负载均衡。系统采用模块化设计,遵循客户端-服务器模式,应用了单例模式、工厂模式和观察者模式等设计模式,提升了代码的可维护性和复用性。 该单点登录系统适用于企业、教育机构或大型网站等需要多应用统一登录的场景,能够有效减少用户重复登录的麻烦,提高安全性和管理效率。系统源码完整,包含详细的文档和部署指南,适合作为计算机科学或软件工程专业的毕业设计项目,帮助学生深入理解微服务架构、单点登录技术和云原生应用开发。资源包括系统源码和配套论文,论文内容涵盖系统需求分析、设计、实现和测试等全过程,为学习者提供全面的参考和实践指导。 通过本资源,用户可以快速搭建一个高可用的单点登录系统,学习到Spring Cloud、CAS、Docker等前沿技术的实际应用,提升项目开发能力和系统设计思维。无论是用于毕业设计、课程项目还是实际部署,本系统都具有较高的实用价值和教学意义。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值