首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。句子中单词以空格符隔开。为简单起见,标点符号和普通字母一样处理。 例如输入“I am a student.”,则输出“student. a am I”。
输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。句子中单词以空格符隔开。为简单起见,标点符号和普通字母一样处理。 例如输入“I am a student.”,则输出“student. a am I”。
admin
2019-03-29
91
问题
输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。句子中单词以空格符隔开。为简单起见,标点符号和普通字母一样处理。
例如输入“I am a student.”,则输出“student. a am I”。
选项
答案
/////////////////////////////////////////////////////////////////////// // Reverse a string between two pointers // Input: pBegin - the begin pointer in a string // pEnd - the end pointer in a string /////////////////////////////////////////////////////////////////////// void Reverse(char *pBegin, char *pEnd) { if(pBegin == NULL || pEnd == NULL) return; while(pBegin < pEnd) { char temp = *pBegin; *pBegin = *pEnd; *pEnd = temp; pBegin ++, pEnd --; } } /////////////////////////////////////////////////////////////////////// // Reverse the word order in a sentence, but maintain the character // order inside a word // Input: pData - the sentence to be reversed /////////////////////////////////////////////////////////////////////// char* ReverseSentence(char *pData) { if(pData == NULL) return NULL; char *pBegin = pData; char *pEnd = pData; while(*pEnd != ’\0’) pEnd ++; pEnd--; // Reverse the whole sentence Reverse(pBegin, pEnd); // Reverse every word in the sentence pBegin = pEnd = pData; while(*pBegin != ’\0’) { if(*pBegin == ’ ’) { pBegin ++; pEnd ++; continue; } // A word is between with pBegin and pEnd, reverse it else if(*pEnd == ’ ’ || *pEnd == ’\0’) { Reverse(pBegin, --pEnd); pBegin = ++pEnd; } else { pEnd ++; } } return pData; }
解析
由于编写字符串相关代码能够反映程序员的编程能力和编程习惯,与字符串相关的问题一直是程序员笔试、面试题的热门题目。本题也曾多次受到包括微软在内的大量公司的青睐。
由于本题需要翻转句子,我们先颠倒句子中的所有字符。这时,不但翻转了句子中单词的顺序,而且单词内字符也被翻转了。我们再颠倒每个单词内的字符。由于单词内的字符被翻转两次,因此顺序仍然和输入时的顺序保持一致。
还是以上面的输入为例子。翻转“I am a student.”中所有字符得到“.tneduts a ma I”,再翻转每个单词中字符的顺序得到“students. a am I”,正是符合要求的输出。
转载请注明原文地址:https://kaotiyun.com/show/IxmZ777K
0
程序员面试
相关试题推荐
TruthinadvertisingisaconceptcentraltotheAmericanfreemarketeconomicsystem.Accordingtothistheory,companiesthat
列举ADO.NET中的五个主要对象,并简单描述
在百度中搜索“腊梅”图片。
在即时通讯工具MSN的界面上,使用邮件按钮,将“我的显示图片”和对方的显示图片设置为一样,均为足球;然后向对方发送消息:“both0fushave!thesamepicture.”。
从当前界面上的菜单或“网络任务”开始创建拨号连接,通过Modem连接到In-ternet,拨号时先拨0,再拨16300,用户名和密码均为16300,将创建的连接的名称命名为:linkl,然后在桌面上创建一个到此连接的快捷方式。除此之外,其余选项均使用默认设
对于PPoint中的视图模式,以下说法错误的是()。A.幻灯片浏览视图下不能设置放映方式B.幻灯片视图注重于对幻灯片的文本和对象进行详细操作C.每种视图模式在演示文稿的制作和显示中有不同的作用D.大纲视图便于查看和编排演示文稿的大纲
对于PPoint中的视图模式,以下说法错误的是()。A.幻灯片浏览视图下不能设置放映方式B.幻灯片视图注重于对幻灯片的文本和对象进行详细操作C.每种视图模式在演示文稿的制作和显示中有不同的作用D.大纲视图便于查看和编排演示文稿的大纲
在foxpro中定义数据库结构时,字段名的宽度最多可以是()。A.2B.4C.10D.16
论IT服务规划设计IT服务规划设计处于IT服务生命周期的前期,如果前期未进行有效的规划设计,那么仓促而就的IT服务就难以满足客户的真正需求,可能造成IT服务可用性降低、客户满意度低下等问题。为确保有效做好IT服务规划设计,服务供方在IT服务规划设计过程中
椭圆曲线密码ECC是一种公开密钥加密算法体制,其密码由六元组T=<p,a,b,G,n,h>表示。用户的私钥d的取值为1._____,公钥Q的取值为2.______。利用ECC实现数字签名与利用RSA实现数字签名的主要区别是3.____
随机试题
我国独立自主的和平外交政策,应坚持把()。
下列哪种疾病大便呈深黄色,粪胆原增多
女,34岁,住院患者.有明显基础代谢增高症状及交感神经兴奋症状,浸润性突眼,甲状腺Ⅲ度弥漫性肿大,质软,双侧甲状腺上下极均可闻及血管杂音。入院后经鉴别诊断,此患者最可能的诊断是
2005年4月7日甲与乙签订货物买卖合同,合同约定甲向乙购买皮装9000套,并向乙预付货款30万元。合同中还约定:“凡因执行本合同所发生的一切争议,提交北京仲裁委员会根据该会的仲裁规则进行仲裁,仲裁裁决是终局的,对双方都有约束力。”2005年4月8日,甲将
金融机构经营外汇业务,须经外汇管理部门批准,领取经营外汇许可证。()
材料: 区域游戏开始后,幼儿自由选择了不同的游戏区,周老师开始巡视指导。当她发现“医院”里“小医生”无事可做时,就赶紧到“娃娃家”提醒“妈妈”宝宝生病了。听到周老师的话后,“爸爸”“妈妈”赶紧抱上“宝宝”去“医院”看“医生”。“饭店”里的“客人”用餐结束
依法对应负治安责任的团体、组织、个人实施治安行政管理的行为属于治安监督检查权。()
最近有很多人对公众事件进行调查,如云南“躲猫猫”事件,杭州“70码”事件,南京“天价烟”事件,并把调查结果在网络上公开。对此你有什么看法?
Forme,scientificknowledgeisdividedintomathematicalsciences,naturalsciencesorsciencesdealingwiththenaturalworld
Heisanexceedinglyinsularman,soprivatelydeepastoseeminaccessibletothescrutinyofanovelist.
最新回复
(
0
)