反转字符串中的单词-创新互联
1、问题描述:
创新互联建站是一家集网站建设,内乡企业网站建设,内乡品牌网站建设,网站定制,内乡网站建设报价,网络营销,网络优化,内乡网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。例:I am student ------>结果为:student am I
算法思想:
先将整个字符串反转一遍,然后在从头开始,遇到空格的在次进行反转,就可以实现反转字符串中的单词了;
2、代码实现
#include#include #include void revStr(char *str, int from, int to); void finalRev(char *str); void finalRev(char *str){ int from = 0; int to = 0; while(str[to]){ while(isalpha(str[to])){ to++; } revStr(str, from, to-1); while(isspace(str[to])){ //针对中间出现多个空格的情况,可以跳跃过去 to++; } from = to; } } void revStr(char *str, int from, int to){ char tmp; while(from < to){ tmp = str[from]; str[from++] = str[to]; str[to--] = tmp; } } void main(void){ char str[80]; char *p = str; int strLen; int count = 0; int i = 0; printf("请输入字符串:\n"); gets(str); strLen = strlen(str); revStr(str, 0, strLen-1); finalRev(str); puts(str); }
3、结果截图
算法分析:空间复杂度为:O(1);
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
标题名称:反转字符串中的单词-创新互联
转载来源:http://pcwzsj.com/article/cejshc.html