博客
关于我
团体程序设计天梯赛-练习集 L1-023 输出GPLT (20分)
阅读量:340 次
发布时间:2019-03-04

本文共 1292 字,大约阅读时间需要 4 分钟。

为了重新排列字符串并按GPLT顺序输出,我们可以使用四个栈分别存储G、P、L、T四个字符。这样在处理每个字符时,可以依次按照GPTL顺序输出字符,确保满足题目的要求。

首先,我们初始化四个栈,每个栈分别用于存储对应的字符。然后遍历输入字符串,遇到每个字符时,将其转换为大写,并将其压入对应的栈中。最后,依次检查每个栈是否为空,非空则取出栈顶字符输出,直到所有栈都为空。

这种方法能够处理各种字符数量不一致的情况,确保输出顺序正确。代码实现时,可以使用C++的stack来实现每个栈,并在主循环中依次输出字符。

以下是实现代码:

#include 
#include
#include
#include
using namespace std;int main() { stack
s1, s2, s3, s4; string str; cin >> str; for (char c : str) { char upper_c = toupper(c); switch (upper_c) { case 'G': s1.push(upper_c); break; case 'P': s2.push(upper_c); break; case 'L': s3.push(upper_c); break; case 'T': s4.push(upper_c); break; } } while (!s1.empty() || !s2.empty() || !s3.empty() || !s4.empty()) { if (!s1.empty()) { cout << s1.top(); s1.pop(); } if (!s2.empty()) { cout << s2.top(); s2.pop(); } if (!s3.empty()) { cout << s3.top(); s3.pop(); } if (!s4.empty()) { cout << s4.top(); s4.pop(); } } return 0;}

这个代码首先读取输入字符串,遍历每个字符并按顺序存储到四个栈中。然后,依次检查每个栈是否为空,非空则输出栈顶字符并弹出,直到所有栈为空。这样,输出的字符串将按照GPLT循环的顺序排列,满足题目的要求。

转载地址:http://tbfe.baihongyu.com/

你可能感兴趣的文章
Nginx 配置清单(一篇够用)
查看>>
Nginx 配置解析:从基础到高级应用指南
查看>>
nginx+php的搭建
查看>>
nginx+tomcat+memcached
查看>>
nginx+Tomcat性能监控
查看>>
nginx+uwsgi+django
查看>>
Nginx-http-flv-module流媒体服务器搭建+模拟推流+flv.js在前端html和Vue中播放HTTP-FLV视频流
查看>>
Nginx下配置codeigniter框架方法
查看>>
Nginx之二:nginx.conf简单配置(参数详解)
查看>>
Nginx代理websocket配置(解决websocket异常断开连接tcp连接不断问题)
查看>>
Nginx代理初探
查看>>
Nginx代理外网映射
查看>>
Nginx代理模式下 log-format 获取客户端真实IP
查看>>
Nginx代理静态资源(gis瓦片图片)实现非固定ip的url适配网络环境映射ip下的资源请求解决方案
查看>>
Nginx反向代理与正向代理配置
查看>>
Nginx多域名,多证书,多服务配置,实用版
查看>>
nginx异常:the “ssl“ parameter requires ngx_http_ssl_module in /usr/local/nginx/conf
查看>>
nginx总结及使用Docker创建nginx教程
查看>>
nginx报错:the “ssl“ parameter requires ngx_http_ssl_module in /usr/local/nginx/conf/nginx.conf:128
查看>>
nginx报错:the “ssl“ parameter requires ngx_http_ssl_module in usrlocalnginxconfnginx.conf128
查看>>