#include<
stdio.h>
#include<string.h>
void main( )
{char a[50],b[20];
int i=0,min=0,lena,lenb;
printf("please input string a:");
gets(a);
printf("please input string b:");
gets(b);
while(a[i]!='\0')// 遍历a[]一遍,找出最小的那个下标
{ if(a[i]<a[min])
min=i;//用min存储最小的那个
i++;}
lena=string(a);
lenb=string(b);
for (i=lena;i>min;i--)//这个循环是将a[]中从min开始到最后的元素都后移lenb个位
// 子, 因为你要在最小元素后插入数组b[],所以你要为数组b[]供
// lenb个位子,
a[i+lenb]=a[i];
for (i=0;i<lenb;i++) //这个循环是从a[min]到a[min+lenb]来存储插入的数组b[],比如你
//是在第5个位子开始插入,就是a[5+0+1]=b[0] ,a[5+1+1]=b[1]
a[min+i+1]=b[i];
puts(a);
}
我重新修改一下。
#include<stdio.h>
#include<string.h>
#include <iostream>
using namespace std;
void main( )
{char a[50],b[20];
int i=0,j=0,min=0,lena,lenb;
printf("please input string a:");
gets(a);
printf("please input string b:");
gets(b);
while(a[i]!='\0')// 遍历a[]一遍,找出最小的那个下标
{ if(a[i]<a[min])
min=i;//用min存储最小的那个
i++;}//i用来表示数组a中有多少个元素
while(b[j]!='\0')// 遍历a[]一遍,找出最小的那个下标
{
j++;}//j用来表示数组b中有多少个元素
lena=i;
lenb=j;
for (i=lena;i>min;i--)//这个循环是将a[]中从min开始到最后的元素都后移lenb个位
// 子, 因为你要在最小元素后插入数组b[],所以你要为数组b[]供
// lenb个位子,
a[i+lenb]=a[i];
for (i=0;i<lenb;i++) //这个循环是从a[min]到a[min+lenb]来存储插入的数组b[],比如你
//是在第5个位子开始插入,就是a[5+0+1]=b[0] ,a[5+1+1]=b[1]
a[min+i+1]=b[i];
puts(a);
system("pause");
}
//这样应该可以了