【面试常考】C语言:输入:"student a am i",输出"i am a student,不能使用库函数

原创 2016年05月30日 17:14:20
#include<stdio.h>
#include <assert.h>

void my_reverse(char *left ,char * right)
{
 assert(left);
 assert(right);   //用以处理指针函数为空,保证有效
 
 while(left < right)
 {
      char tmp =  *left;  //借助中间变量实现逆置
      *left =  *right;
      *right = tmp;
      left ++;
      right --;
 }
 
}


int my_strlen(char *str)//得到数组长度定义求取字符串长度的函数
{
     int count = 0;
     while(*str++)
     {
          count ++; 
     } 
     return count; //返回count指向int型的具体值
}


void reverse(char arr[])  //char *arr
{ 
     char *pstart = arr;
     char *pend = arr + my_strlen(arr) -1; //注意数组从0开始
     char *pcur = NULL;
     if((arr == NULL) || (arr[0]=='\0')) //空数组或数组结束,不处理
     {
          return ;   
     }
     my_reverse(pstart,pend);  //逆置整个数组
     while(*arr)//不为NULL,为‘\0’的情况
     {
          pcur =arr;  //数组开始地址
          while(*arr !='\0' && *arr !=' ')  //在单词内部时
          {
               arr++;
          }
          pend =arr - 1;  //退一位
          my_reverse(pcur, pend);    //逆置遇到空格的单词
          if(*arr == ' ')  //说明后面还有单词 
          {
               arr++; 
          }
     }
}


int main()
{
     char arr[] = "student a am i";  
     //思路:先将字符串逆置,再遇到空格处将该单词逆置即可
     reverse(arr);
     printf("%s\n",arr);
     return 0; 
}

wKiom1Y0Pf-Cth4SAADIeoaWUZc883.jpg

相关文章推荐

【C语言】”student a am i “和“we are happy”

1.有一个字符数组的内容为 : “student a am i”, 请你将数组的内容改为”i am a student”....

面试经典题目:字符串翻转I am a student

题目:写一个函数,将字符串翻转,翻转方式如下:“I am a student”反转成“student a am I”,不借助任何库函数 ,要求单词内字符的顺序不变,句子中单词以空格符隔开。 思路:先反...
  • gotowu
  • gotowu
  • 2015年11月18日 15:15
  • 1830

面试题------字符串翻转I am a student

题目描述:编写函数,输入一个英文的句子,翻转句子中单词的顺序。要求单词内字符的顺序不变,单词间空格符数量不变。 例如:"I am a student."反转成"student. a am I"。 ...

反转字符串I am a student

//写一个函数,将字符串翻转,翻转方式如下:“I am a student”反转成“student a am I”,不借助任何库函数。 方法是先反转整个字符串,然后再反转字串。譬如先将“I ...
  • tc216
  • tc216
  • 2015年08月25日 14:15
  • 169

【C语言】有一个字符数组的内容为:"student a am i",请你将数组的内容改为"i am a student".

有一个字符数组的内容为:"student a am i",请你将数组的内容改为"i am a student". 要求: 不能使用库函数。只能开辟有限个空间(空间个数和字符串的长度无关)。...

C 语言字符串 将一行字符串I am a student。逆序输出student。a am I;

方法1 #include #include #define N 4//单词的个数 #define M 20//单词的长度 int main(void) { char str[N][M...

手把手教你使用“谷歌云消息服务(GCM)&quot;

原文: http://android.eoe.cn/topic/summary GCM结构概述-GCM Architectural Overview 快速预览* 一...

不知道发布端(即服务器端)是哪种发布技术的情况下,客户端使用axis去调用,报错:unexpected element (uri:&quot; Expected elements are &lt;

不知道发布端(即服务器端)是哪种发布技术的情况下,客户端使用axis去调用,报错: {http://xml.apache.org/axis/}stackTrace:Unmarshalling E...

单词翻转(i am a student)--->>(student a am i)

问题描述: 写一个函数将i am a student  转化为  student a am i 解题思路: //i am a student --->--> student a am ...

有一个字符数组的内容为:"student a am i",请你将数组的内容改为"i am a student".

用数组实现: #include int strlen(char *arr) { char *ret=arr; while((*ret++)!='\0') ; return ret-arr...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:【面试常考】C语言:输入:&quot;student a am i&quot;,输出&quot;i am a student,不能使用库函数
举报原因:
原因补充:

(最多只允许输入30个字)