#include"string.h"
#include
main()
{char a[100],x;
int len,i,wz;
printf("input:\n");
scanf("%d%c%s",&wz,&x,a);
len=strlen(a);
printf("\n");
for(i=len-1;i>=wz-1;i--)
a[i+1]=a[i];
a[wz-1]=x ;
a[len+1]='\0';
printf("%s\n",a) ;
}
输入的时候注意了,回车结束,例如输入:4dabcef 结果:abcdef 希望有所帮助 ,WZ表示位置,x表示要插入的字符,a表示字符串,当然你可以判断输入的位置是否超过字符串的长度,我就不写了,推荐下^_^
也许用链表比较好实现,下面是用数组实现的程序:
#include
#include
main()
{ int i,j,k,m,n;
char a[100],b[100],c;
gets(a);
gets(b);
c=getchar();
m=strlen(a);
设计过程: 定义两个字符串s2,s2,字符k 输入两个字符串 s1 、 s2 和 s1 中任意字符 k 先遍历 s1 找到指定字符 k,记录下当前位置 从k字符开始,按s2的长度后移其余的数据 将s2拷贝到k所在的位置 输出s1。 代码如下: #include
for(i=0;i
{if(a[i]==c)
break;
}
if(i>=m)
{printf("出错!\n");
return;
}
n=strlen(b);
k=m;
for(j=m+n;j>i;j--,k--)
a[j]=a[k];
for(j=i,k=0;j
a[j]=b[k];
printf("%s\n",a);
}
#include
void main()
{
char s1[100];
char s2[20];
char k;
int i,pos,len;
printf("input s1: ");scanf("%s", s1 );
printf("input s2: ");scanf("%s", s2 );
getchar();//滤掉回车符
printf("input k: ");scanf("%c", &k );
for( i=0;s1[i];i++ )
if ( s1[i]==k )
break;
}
pos=i; //记录下待插入的位置
len=strlen(s2); //得到s2长度
for( i=strlen(s1);i>=pos;i-- ) //后移字符串
{
s1[i+len]=s1[i];
}
strncpy( &s1[pos], s2, len ); //插入数据
printf("%s\n", s1 ); //输出字符串
}
#include
#include
//输入一个字符串,在指定位置插入一个字符的c语言怎么写
void insertCharacter(char a[], int n,char c);
void print(char a[]);
int main(int argc, const char * argv[]) {
char a[100];
char c;
int n;
printf("请输入一个字符串:\n");
gets(a);
printf("请输入你要插入的位置,要插入的字符:\n");//下标从0开始 输入空格隔开
scanf("%d %c", &n, &c);
insertCharacter(a, n, c);
print(a);
return 0;
}
void insertCharacter(char a[], int n, char c)
{
int i;
for (i = strlen(a)+1; i >n ; i--) {
a[i]=a[i-1];
}
a[n] = c;
}
void print(char a[])
{
int i;
for (i = 0; i < strlen(a); i++) {
printf("%c", a[i]);
}
}
楼主你的思想错了,当你找到s[i]==c1,你让s[j]=c2,s[j+1]=s[i],这个时候就把原来的s[j+1]的字符覆盖掉了,应该在找到插入位置后将插入位置后面的字符全都往后退一位,空出来的位置再给插入的字符。