华北计算所其中一道机试题,逆转字符串,但是单词顺序不变

2023-12-07 15:08

本文主要是介绍华北计算所其中一道机试题,逆转字符串,但是单词顺序不变,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

/*
华北计算所其中一道机试题,逆转字符串,但是单词顺序不变,字符串中只含有字母和空格。

比如this is a book,逆序后为book a is this
Author:shizhixin
Email:szhixin@gmail.com
Blog:http://blog.csdn.net/ShiZhixin
Data:Oct 25,2009
*/

#include "stdafx.h"
#include <iostream>
using namespace std;
#include <string>
//初步版本,记得面试时候这么写的,但是开始有点问题,指针移动的时候
// void InverseStr(char* cpStrOutput,char* cpStrInput,int length)
// {
//     int nAllCount=0;//当前处理的总字母的个数
//     for (int i=0;i<length;i++)
//     {
//         int nLetterCount=0;//计算单个单词的字母个数
//         const char* temp=cpStrInput;
//         while(*cpStrInput!=' ' && *cpStrInput!='/0') //机试好像也忘记判断/0的情况了
//         {
//             nLetterCount++;
//             cpStrInput++;
//             i++;
//         }
//         if (*cpStrInput!='/0')//记得机试的错误主要在这里当时紧张这都没调试出来,没有这个的话,他一直处在cpStrInput空格位置了
//         {
//             cpStrInput++;
//         }
//         nAllCount+=nLetterCount;
//         for (int j=0;j<nLetterCount;j++)
//         {
//             cpStrOutput[length-nAllCount+j]=*temp;//temp很不专业!
//             temp++;
//         }
//         if (*temp!='/0')//不加判断的话,最后一个单词length-nAllCount-1成为-1了,所以main中delete时出现错误!   
//         {
//             cpStrOutput[length-nAllCount-1]=*temp;       
//         }
//         nAllCount++;
//         temp++;
//     }
//     cpStrOutput[length]='/0';
// }

// 输入参数为const类型,
void InverseStr(char* cpStrOutput,const char* cpStrInput,int length)
{
    const char* pMove=cpStrInput; //另设两个变量移动指针
    const char* pGetValue=cpStrInput;
    int nAllCount=0;//当前处理的总字母的个数,这里不用这个变量,直接用当前处理的i
    for (int i=0;i<length;i++)
    {
        int nLetterCount=0;//计算单个单词的字母个数
        while(*pMove!=' ' && *pMove!='/0')
        {
            nLetterCount++;
            pMove++;
            i++;
        }
        if (*pMove!='/0')
        {
            pMove++;
        }
        for (int j=0;j<nLetterCount;j++)
        {
            cpStrOutput[length-i+j]=*pGetValue;
            pGetValue++;
        }
        if (*pGetValue!='/0')
        {
            cpStrOutput[length-i-1]=*pGetValue;
        }
        pGetValue++;
    }
    cpStrOutput[length]='/0';
}

int main(int argc, char* argv[])
{
    char* strInput="My blog is blog.csdn.net/shizhixin";
    int nLen=strlen(strInput);
    char* strOutput=new char[nLen+1];
    InverseStr(strOutput,strInput,nLen);
    cout<<strOutput<<endl;
    if (strOutput!=NULL) //记得机试的时候也没释放内存,这么低级的错误,艾,考试就蒙了
    {
        delete[] strOutput;   
        strOutput=NULL;
    }       
    return 0;
}

这篇关于华北计算所其中一道机试题,逆转字符串,但是单词顺序不变的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/466327

相关文章

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

Python 常用数据类型详解之字符串、列表、字典操作方法

《Python常用数据类型详解之字符串、列表、字典操作方法》在Python中,字符串、列表和字典是最常用的数据类型,它们在数据处理、程序设计和算法实现中扮演着重要角色,接下来通过本文给大家介绍这三种... 目录一、字符串(String)(一)创建字符串(二)字符串操作1. 字符串连接2. 字符串重复3. 字

Java 字符串操作之contains 和 substring 方法最佳实践与常见问题

《Java字符串操作之contains和substring方法最佳实践与常见问题》本文给大家详细介绍Java字符串操作之contains和substring方法最佳实践与常见问题,本文结合实例... 目录一、contains 方法详解1. 方法定义与语法2. 底层实现原理3. 使用示例4. 注意事项二、su

JAVA实现亿级千万级数据顺序导出的示例代码

《JAVA实现亿级千万级数据顺序导出的示例代码》本文主要介绍了JAVA实现亿级千万级数据顺序导出的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 前提:主要考虑控制内存占用空间,避免出现同时导出,导致主程序OOM问题。实现思路:A.启用线程池

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

python 线程池顺序执行的方法实现

《python线程池顺序执行的方法实现》在Python中,线程池默认是并发执行任务的,但若需要实现任务的顺序执行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录方案一:强制单线程(伪顺序执行)方案二:按提交顺序获取结果方案三:任务间依赖控制方案四:队列顺序消

Java使用正则提取字符串中的内容的详细步骤

《Java使用正则提取字符串中的内容的详细步骤》:本文主要介绍Java中使用正则表达式提取字符串内容的方法,通过Pattern和Matcher类实现,涵盖编译正则、查找匹配、分组捕获、数字与邮箱提... 目录1. 基础流程2. 关键方法说明3. 常见场景示例场景1:提取所有数字场景2:提取邮箱地址4. 高级

Python 字符串裁切与提取全面且实用的解决方案

《Python字符串裁切与提取全面且实用的解决方案》本文梳理了Python字符串处理方法,涵盖基础切片、split/partition分割、正则匹配及结构化数据解析(如BeautifulSoup、j... 目录python 字符串裁切与提取的完整指南 基础切片方法1. 使用切片操作符[start:end]2

MyBatis的xml中字符串类型判空与非字符串类型判空处理方式(最新整理)

《MyBatis的xml中字符串类型判空与非字符串类型判空处理方式(最新整理)》本文给大家介绍MyBatis的xml中字符串类型判空与非字符串类型判空处理方式,本文给大家介绍的非常详细,对大家的学习或... 目录完整 Hutool 写法版本对比优化为什么status变成Long?为什么 price 没事?怎

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1