面试题--字符串指针与字符串数组的区别char* st="abc;与char* str[]="abc";的异同

来源:互联网 发布:java开源项目代码 编辑:程序博客网 时间:2024/05/22 03:24

题1.   删除串中指定的字符(做此题时,千万不要开辟新空间,否则面试官可能认为你不适合做嵌入式开发)

参考代码:

void delChar(char* str, char c) {int i, j=0;int len=strlen(str); for(i=0; i<len; i++)  if(str[i]!=c)   str[j++]=str[i]; str[j] = '\0';}void main(void) {  char str[] = "abcdefgh"; // 注意,此处不能写成char *str = "abcdefgh";why??  delChar(str, 'c');   printf("%s\n", str);}
关于这里为什么不能用char *str = "abcdefgh";用了程序编译没错,运行出错。

这是因为char *str = "abcdefgh";这里str指向的是常量字符串,str指向的内容是不能修改的,(str的值是可以修改的,比如再char s[10];str=s;是可以的),因此函数调用后对其指向的字符进行修改是错误的。

再看一个例子:

void stringCopy(char *from,char *to);void main(){  //char a[] = "I am a teacher."; char b[] = "You are a student.";  char *a = "I am a teacher.";      //  char *b = "You are a student.";  printf("a= %s\nb=%s\n",a,b);  printf("copy string a to b :\n");  stringCopy(a,b) ;                       //  实参是指针变量  printf("a= %s\nb=%s\n",a,b);}// 子函数 实现两个字符串的复制void stringCopy(char *from,char *to)     // 形参是指针变量{      for (;*from !='\0';from++,to++)   {   *to = *from;   }   *to='\0';}
这里

char *a = "I am a teacher.";      
char *b = "You are a student.";
a,b保存的是常量数据区地址,a,b指向的内容不能被修改
所以函数里面的赋值是不起作用的.
应该改成这样
char a[] = "I am a teacher.";      
char b[] = "You are a student.";
字符串传给字符数组,a,b保存的是栈区地址,这样传进函数就可以修改其内容了.

因为程序修改是数组b 的内容,所以这样也是可以的:

 char b[] = "You are a student.";
  char *a = "I am a teacher.";   

总结:char * 和char[]都可以用来表示字符串,但两者有很大的不同。其中最主要的不同就是char *所表示的字符串,是不能修改的,而char[]所表示的字符串是可以修改的。


题2:删除字符串中的数字并压缩字符串(神州数码以前笔试题),如字符串”abc123de4fg56”处理后变为”abcdefg”。注意空间和效率。


参考:(下面的算法只需要一次遍历,不需要开辟新空间,时间复杂度为O(N))

void DelNumberOfStr(char* str) 
{
int i, j=0;
int len=strlen(str);
 for(i=0; i<len; i++)
 {
if(str[i]>='0'&&str[i]<='9') 
  ; // continue;
else 
 str[j++]=str[i];
 }
 str[j] = '\0';
}

题3:不开辟用于交换数据的临时空间,如何完成字符串的逆序(在技术一轮面试中,有些面试官会这样问)

void change(char *str)
 {
      int len=strlen(str)
for(int i=0,j=len-1; i<j; i++, j--)
{
str[i]=str[i]^str[j];//a=a^b;
str[j]=str[i]^str[j];//b=a^b;
str[i]=str[i]^str[j];//a=a^b;
}
}

0 0
原创粉丝点击