1.创作原因:我看在了很多这题的解法可是看到很多朋友用的都是gets函数,这函数有个致命缺点这个大家都知道就不多说了,早期很多爬虫病毒都有这哥们的影子,所以我用fgets函数写了一个解法出来
2.代码
#include<stdio.h>
#include<string.h>
int main()
{
char a[100], b[100];
int i, j, max=0, min=0;
fgets(a,100,stdin);//不安全,fgets(a,n,stdin)是从输入流中提取n个字符,或者遇到回车为止
int len = strlen(a);
for (i = 0; i < len-1; i++)//对a遍历找最小字符
{
if (a[min] > a[i])
{
min = i;
}
}
fgets(b,100,stdin);
int len1 = strlen(b);
for (i = 0; i < len-1; i++)//对b找最大字符
{
if(b[max]<b[i])
{
max = i;
}
}
for(j = len;j>min;j--)//组出新数组
{
a[j] = a[j - 1];
}
a[j+1] = b[max];
fputs(a,stdout);//输出字符串并换行,puts()内是放字符串起始地址,所以数组名也可行
return 0;
}
3.对fgets函数的一些处理,因为fgets函数会保留下来'\n'也就是回车会占用一个数组空间,所以用len-1来除去回车。
新手上路,欢迎各位大佬朋友发言交流。