- 1、本文档共2页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
PTA刷题C语⾔编程顺序颠倒输出实现
⽬录
这道题,是我遇见对数组元素的掌握与使⽤较为灵活的题⽬。
下⾯代码是我刚接触C++,刚学完类的⼀系列知识,连⼊门都没过,对C++的强⼤还未有多⼤认知,还是极具C语⾔的风格。
我看过⼀篇⽤C++完成的⽐这个简单多了。
C语⾔也可以⽤栈来完成,虽然我有栈的实现函数,但我不愿去搞,就这样吧,实现也是对⾃⼰知识点掌握的加深认知。
#includeiostream
#includecstring
intmain(void)
{
inta=0;
charch;
chararr1[500001];//输⼊数组
chararr2[500001];//输出数组
while((ch=getchar())!=\n)//读⼊字符串
{
arr1[a++]=ch;
}
arr1[a]=\0;
intlen=strlen(arr1);
inti=0;
intdest=len-1;//从字符串尾部开始遍历
while(dest=0)
{
if(arr1[dest]==arr1[dest+1]!=arr1[dest+1]!=\0||(dest==0arr1[0]!=))//元素为单词的条件
{
if(i!=0)
arr2[i++]=;
intlast=dest+1;
if(dest==0arr1[0]!=)//满⾜条件,改变last的值
{
last=dest;
}
while(arr1[last]!=arr1[last]!=\0)//将单词拷贝到输出数组中
{
arr2[i++]=arr1[last++];
}
}
dest--;
}
arr2[i]=\0;//字符串结束
std::coutarr2std::endl;
return0;
}
尽量理解吧
arr1[dest]==arr1[dest+1]!=arr1[dest+1]!=\0
是为了确定每个单词出现的条件。
(dest==0arr1[0]!=)
是为了处理第⼀个元素就是单词的情况。
while(arr1[last]!=arr1[last]!=\0)
{
arr2[i++]=arr1[last++];
}
负责将单词拷贝到输出数组上,同时符号要求。
if(i!=0)
arr2[i++]=;
这个是,当第⼀个单词拷贝过去后,判断是否后⾯还有有单词,且能进这个域,就代表后⾯还有单词,要加⼀个空格的元素。
以上就是PTA刷题C语⾔编程顺序颠倒输出实现的详细内容,更多关于PTA刷题C语⾔倒序的资料请关注其它相关⽂章!
文档评论(0)