解题思路:
利用指针解决这个问题。
1.利用实参传指针的方法,实现在被调函数中指针的赋值,然后就是确定c1的位置k,当k=m时,p1也就指向了*p这个数值;
2.然后将数组第m位的值赋给数组c2,赋值结束后,p1++,p2++;
注意事项:
1.要注意在给数组c1赋值完后要添加结束符'\0',用指针表示则是*p1=0,用数组表示则是c1[n]=0;
参考代码:
#include<stdio.h>
#include<string.h>
void cpy(char *p1,char *p2,int m)
{
int k=0;
while(k<m-1)
{
k++;
p1++;
}
while(*p1!='\0')
{
*p2=*p1;
p1++;
p2++;
}
*p2=0; //加上结束符
}
int main()
{
char c1[100],c2[100];
int i,n,m;
scanf("%d",&n);
getchar(); ////读取上一个输入的换行符
for(i=0;i<n;i++)
{
scanf("%c",&c1[i]);
}
c1[n]=0; //加上结束符
scanf("%d",&m);
cpy(c1,c2,m);
puts(c2);
return 0;
}
0.0分
1 人评分
C语言程序设计教程(第三版)课后习题6.1 (C语言代码)浏览:664 |
求组合数 (C语言代码)浏览:1152 |
三角形 (C++代码)递归(存在大量重复计算,容易出现时间超限)浏览:774 |
C语言考试练习题_一元二次方程 (C语言代码)浏览:575 |
C语言程序设计教程(第三版)课后习题9.3 (C语言代码)浏览:668 |
C语言程序设计教程(第三版)课后习题5.6 (C语言代码)浏览:556 |
C语言程序设计教程(第三版)课后习题6.4 (C语言代码)浏览:1189 |
C语言训练-斐波纳契数列 (C语言代码)浏览:503 |
C二级辅导-公约公倍 (C语言代码)浏览:658 |
蓝桥杯基础练习VIP-报时助手 (C++代码)浏览:1053 |