SDUT 3437 排序算法

本文解析了SDUT OJ编号3437的题目,该题要求对给定的字符串进行字母排序。介绍了使用哈希表和桶排序的方法,并通过示例代码展示了如何高效地解决问题。

题目链接: http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=3437

排序算法

Time Limit: 300ms   Memory limit: 65536K  有疑问?点这里^_^

题目描述

这是一个简单的排序题!
题面也很简单!
给你一个字符串(保证只包含a~z),把其中的字母按照字母顺序排序!
是不是很简单!
我想你已经迫不及待了吧!
Accept it!

输入

多组输入,(约100组),处理到文件结束
每组只有一行,包含一个字符串S(|S| < = 10000000),保证只含有a到z的字符 

输出

每组输入输出排序好的字符串

示例输入

zba

示例输出

abz

提示

 

来源

QAsQ
恩 我不会告诉你这题是得用哈希加桶排的 QAQ
好吧 既然你知道了,那我也不多说了,当初做的时候我连哈希都不知道,这道水题硬是白白没有A掉
首先解释一下300ms时间限制的由来
  1. #include <cstdio>  
  2. #include <cstring>  
  3. #include <algorithm>  
  4. using namespace std;  
  5. char s[10000005];  
  6. int cmp(const void *a, const void *b)  
  7. {  
  8.     return *(char *)a-*(char *)b;  
  9. }  
  10. int main()  
  11. {  
  12.     while(~scanf("%s", s))  
  13.     {  
  14.         qsort(s,strlen(s),sizeof(s[0]),cmp);  
  15.         printf("%s\n", s);  
  16.     }  
  17.     return 0;  
  18. }  
结果是。。
1481819
3437 Time Limit Exceeded 310ms 0KB g++ 336B 2016-05-06 22:41:53
出题人应该是预料到会有人用qsort对字符串排序了233
下面是真正的代码
  1. #include <bits/stdc++.h>  
  2. char s[10000005];  
  3. int a[26];  
  4. using namespace std;  
  5. int main()  
  6. {  
  7.     while(~scanf("%s", s))  
  8.     {  
  9.         memset(a,0,sizeof(a));  
  10.         int n=strlen(s);  
  11.         for(int i=0;i<n;i++)  
  12.             a[s[i]-'a']++;  
  13.         for(int i=0;i<26;i++)  
  14.             for(int j=1;j<=a[i];j++)  
  15.             printf("%c"'a'+i);  
  16.         printf("\n");  
  17.     }  
  18.     return 0;  
  19. }  

内容概要:本文围绕“基于交流潮流的电力系统多元件N-k故障模型研究”展开,深入探讨了利用Matlab代码实现电力系统在发生多个关键元件同时故障(即N-k故障)情况下的交流潮流计算与故障分析方法。该模型不仅考虑了传统潮流方程的非线性特性,还引入了故障约束条件,能够精确模拟复杂多样的故障场景,如短路、断线等,进而评估电网在极端运行条件下的稳态与动态行为。研究通过构建典型电力系统算例,验证了所提模型在故障筛选、脆弱性识别及系统恢复策略制定方面的有效性,为电力系统安全评估、风险预警和防御体系构建提供了坚实的理论依据和技术支撑。此外,模型具备良好的扩展性,可进一步应用于连锁故障传播分析、恶意攻击模拟等高级安全分析领域。; 适合人群:具备电力系统分析基础理论知识和Matlab编程能力的高校研究生、科研院所研究人员以及电力公司从事电网规划、运行与安全管理的技术人员,特别适用于开展电力系统安全稳定、可靠性评估与应急响应机制研究的专业人士。; 使用场景及目标:①开展电力系统在多重故障条件下的交流潮流仿真,评估系统电压稳定性、线路过载风险及负荷损失程度;②识别电网中的关键薄弱环节与脆弱元件,支撑电网加固改造与防御资源配置;③用于科研项目中的故障场景建模与算法验证,或作为教学案例帮助学生理解复杂故障下的系统响应机制。; 阅读建议:此资源以Matlab代码为核心实现手段,建议读者结合理论推导与代码实现进行对照学习,重点关注故障建模过程中雅可比矩阵的修正方法、故障注入方式及收敛性处理策略,建议在仿真中逐步增加故障数量与复杂度,深入理解N-k故障对系统潮流分布的影响规律,并尝试将其拓展至含新能源接入的现代电力系统场景中进行验证与优化。
【重要提示】本资源设置为0积分下载,若非0积分请勿轻易下载 亲爱的CSDN用户: 首先感谢你点进这个资源页面。我需要提前说明一个重要情况: 本资源原本已设置为“0积分下载”,即作者希望完全免费共享。但CSDN平台有时会根据文件的下载热度、文件大小、用户权限等因素,自动将部分资源的积分调整为非0数值(如1积分、2积分、5积分等)。这是平台系统的自动行为,而非作者本人的设定。 因此,如果你当前看到该资源的下载所需积分不是0(例如显示为1、2、3……),请谨慎决定是否下载。 如果你按照非0积分支付并下载后发现资源内容不符合预期、链接失效,或者实际上该资源本应是免费的,作者无法为此承担积分损失或退还操作。强烈建议:仅在页面显示为0积分时进行下载。 另外,本资源描述中并未直接提供具体的下载地址或外部链接,因为它本身是一个通过CSDN官方上传通道提交的文件/内容包。如果你看到描述中没有外部网盘地址,这是正常的——资源文件应通过CSDN内置的“下载”按钮获取。若因平台积分显示异常导致你支付了积分,请优先联系CSDN客服咨询积分退还政策,作者没有权限修改平台自动设定的积分值。 感谢你的理解与支持。技术分享本应开放,但受限于平台规则,特此提醒如上。祝学习进步!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值