背景交代
大一下又遇到字符串压缩这道题。
对此处的语法忘得差不多了,去查了下网上大佬的答案,基本都是用的字符数组的做法。题目中已给出的头文件没有string.h,意味着不能使用strlen这个函数。虽然可以用size代替,但还是想过过指针这道坎,于是开始了尝试。。。
尝试代码段
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
void text(char *s)
{
char *p;
p=&s[0];
printf("%c",*s);
//s++;
printf("%c",*s+2);
printf("%c",*s);
s=s+2;
printf("%c",*s);
s=&s[0];
printf("%c",s[0]);
printf("%c",*s);
printf("%c",*p);
}
int main()
{
char s[100000]="ABCDEFG";
text(s);
return 0;
}
输出结果:ACACCCA
总结
*的专业名称是解引用符号(?好像是这个吧)。简单而言,分为两种用法
1.*s++(先赋值再自增)、*++s(先自增再赋值)、*s 这些是指向s这个指针之前指向的那个数组,自增自减意味着指针向后向前。
2.printf("%c",*s); 这个是取s指向的这个位置上的字符,然后输出。
当*s++后,就意味着向后移动了,当再次想要其指回某个前面的元素,是无法实现的。对于指针s来说,它的s[0]是它当前这个位置,而它的s[1]则是当前这个位置的下一位置。这里给出的解决方法是,像实验所说的,提前准备个指针p,用于指向数组的开头。