题目思路还是很清晰:
前m个元素放到后面 下标为0 到 m-1的元素放到另外一个数组的n-m下标((n-1)-(m-1) = n-m)开始的位置;
1.一个命名不规范节省了几分钟,找bug需要花一个小时。。。。。。
/**
* 问题描述:
* 有一个字符串s,包含n个字符,写一个函数,
* 将s中的前m(0<m<n)个字符全部赋值到一个全新的字符串t中后
* 将s后面的n-m个字符全部复制到t的前面
*/
#include <stdio.h>
#define MAX 100
int getline1(char *s, int lim);
void main()
{
int i, n, m;
char s[MAX], t[MAX], *sp, *tp;
printf(" a string:\n ");
//从键盘输入获取一行字符 并且返回统计的字符的数目
n = getline1(s, MAX);
printf(" Input :m=(0<m<%d)\n", n);
scanf("%d", &m);
//直接将指针指向需要存取的数组的具体的某个位置
sp = &s[0];
tp = &tp[n - m]; //考虑边界问题 为了两段之间不产生间隙s
for (i = 0; i < m; i++)
{
*(tp++) = *(sp++);
printf("tp == %c\n",(*tp));
printf("sp == %c\n",*sp);
}
for (i = 0, tp = &t[0]; i < n - m; i++)
{ //tp与 sp是两个数组
*tp++ = *sp++;
}
printf("Initial array:\n");
for (i = 0; i < n; i++)
{
printf("%c", s[i]);
}
printf("\n");
printf("Changed array:\n");
//数组输出
for (i = 0; i < n; i++)
{
printf("%c", t[i]);
if(t[i] ==' '){
printf("=================");
}
}
}
//get line into s, return length 自定义的函数
int getline1(char *s, int lim)
{
int c;
//指向数组的第一个元素的地址
char *sp = s;
//从左到右边开始遍历
while (--lim > 0 && (c = getchar()) != '\n')
{
*sp++ = c;
}
//如果传入的字符是空的字符(循环结束的条件) -- 还是需要将字符添加到字符的末端
if (c == '\n')
{
*sp = c;
}
return (sp - s);
}