您好,输出结果为“a2yz”。
从策划到设计制作,每一步都追求做到细腻,制作可持续发展的企业网站。为客户提供网站制作、做网站、网站策划、网页设计、域名注册、网络空间、网络营销、VI设计、 网站改版、漏洞修补等服务。为客户提供更好的一站式互联网解决方案,以客户的口碑塑造优易品牌,携手广大客户,共同发展进步。
程序图片:
分析:
strcpy(a+1,b+2)相当于将a[1]及它后面的内容复制为b[2]及它后面的内容。b[2]及后面为“2”,因此复制后a为“a2”;
strcat(a,c+1)相当于在a的末尾加上c[1]及其后面的部分,也就是“yz”。故运行后a为“a2yz”
拓展资料:
strcpy把从src地址开始且含有'\0'结束符的字符串复制到以dest开始的地址空间,返回值的类型为char*。
strcat把src所指向的字符串(包括“\0”)复制到dest所指向的字符串后面(删除*dest原来末尾的“\0”)。
参考资料:
百度百科
#includestdio.h
char *custom_cpy(char *to,char *from);
int main(int argc,char *argv[]){
char *from = "i like c langanger";
char to[30];
char *ptr = custom_cpy(to,from);
printf("%s,%s\n",ptr,to);
return 0;
}
char *custom_cpy(char *to,char *from){
if(to == NULL || from == NULL){
return NULL;
}
char *p = to;
for(;*from!='\0';from++,to++){
*to = *from;
}
*to = '\0';//拷贝完毕之后一定要加一个结束符号
return p;
}
扩展资料:
字符串相关函数应用:
1. 连接运算 concat(s1,s2,s3…sn) 相当于s1+s2+s3+…+sn。
例:concat(‘11’,'aa’)='11aa’;
2. 求子串。 Copy(s,I,I) 从字符串s中截取第I个字符开始后的长度为l的子串。
例:copy(‘abdag’,2,3)=’bda’;
3. 删除子串。过程 Delete(s,I,l) 从字符串s中删除第I个字符开始后的长度为l的子串。
例:s:=’abcde’;delete(s,2,3);结果s:=’ae’;
4. 插入子串。 过程Insert(s1,s2,I) 把s1插入到s2的第I个位置
例:s:=abc;insert(‘12’,s,2);结果s:=’a12bc’;
5. 求字符串长度 length(s) 例:length(‘12abc’)=5;
参考资料:
百度百科-字符串
你的这一段代码有语法错误:
if(a[j]a[min])min=j;
temp=a[i];
a[i]=a[min];
a[min]=temp;
你的意思是如果a[j]a[min]成立的话,则执行一下所有语句。但是这样写的话只能执行第一条语句:min=j;剩下的无法执行。因为if语句执行到第一个分号就会结束了。所以简单的改一下:
if(a[j]a[min])
{
min=j;
temp=a[i];
a[i]=a[min];
a[min]=temp;
}
这样就可以了。不过即使这样改了后你的代码仍然不能实现需要的功能。我给你分析下:
就是这段代码:
for (i=0;i9;i++)
{
k=i+1;
min=i;
for(j=k;j10;j++)
if(a[j]a[min])
{
min=j;
temp=a[i];
a[i]=a[min];
a[min]=temp;
}
}
你的本意是想用冒泡排序法对其进行排序。不过仔细看一下可以发现,你的冒泡法用的有错误!假设只对4个数排序:4,2,1,3;
i=0时,k=1,min=0,j=1时,因为a[1]a[0],所以a[j]a[min],满足if的条件。所以min=1,并对两数进行互换。结果为:a[0]=2,a[1]=4。j=2时,因为a[2]a[1],所以a[j]a[min]。满足if的条件。所以min=2,并对两数进行互换。结果为:a[1]=1,a[2]=4。j=3时,因为a[3]a[2],所以a[j]a[min],满足if的条件。所以min=3,并对两数进行互换。结果为:a[2]=3,a[3]=4。此时,a[0]=2,a[1]=1,a[2]=3,a[3]=4。
i=1时,k=2,min=1,j=2时,因为a[2]a[1],所以a[j]a[min],不满足if条件。j=3时,因为a[3]a[1],所以a[j]a[min],不满足if条件。此时:a[0]=2,a[1]=1,a[2]=3,a[3]=4。
i=2时,k=3,min=2,j=3时,因为a[3]a[2],所以a[j]a[min],不满足if条件。此时:a[0]=2,a[1]=1,a[2]=3,a[3]=4。
有此可见,这段代码并不能实现对这四个数从小到大的排序。其实冒泡排序很简单的,我建议你看一下它的源代码。我给你简化一下:
#include stdio.h
void main()
{
int a[10],i,j,k,temp,min;
printf ("Enter 10 numbers:15 -24 10 43 -12 52 -61 33 -23 8 \n");
for (i=0;i10;i++)
scanf ("%d",a[i]);
for (i=0;i9;i++)//选择排序法
{
for(j=i+1;j10;j++)
if(a[j]a[i])
{
temp=a[j];
a[j]=a[i];
a[i]=temp;
}
}
/*for(i=1;i10;i++)//冒泡排序法
for(j=0;j10-i;j++)
if(a[j]a[j+1])
{
temp=a[j];
a[j]=a[j+1];
a[j+1]=temp;
}*/
printf("the sored numbers:\n");
for (i=0;i10;i++)
printf ("%d,",a[i]);
}
你可以选择冒泡排序和选择排序,两个方法都差不多。
对于strcpy()这个字符串函数用起来简单。写段简单的代码:
#include stdio.h
#includestring.h
main()
{
char str1[100],str2[100];
printf("input a string:");
gets(str1);
strcpy(str2,str1);
puts(str2);
}
记得加上头文件#includestring.h就可以了。
希望可以帮到你啊,呵呵
1、首先需要建立一个新的文件,输入头文件和主函数。
2、接下来需要定义变量类型。
3、设置完变量类型之后开始调用cpy函数。
4、接下来需要定义一个函数,并定义变量类型。
5、最后加一个字符串结束符,并在主函数中输出。
6、编译。运行,可以看到字符串a复制到字符串b中。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include stdio.h
#include time.h
/*把从src地址开始的字符串复制到以dest开始的字符串中*/
char* strcopy (char* dest, char *src) {
char* r = dest;
while((*r++ = *src++)!='\0');
return dest;
}
int main () {
char *str1="abcde";
char *str2;
str2 = strcopy (str2, str1); /*把str1复制到str2*/
puts (str2);
return 0;
}
他是字符串的复制,函数strcpy(字符数组1,字符串2)作用就是 将字符串2复制到字符数组1 中去。
例如 char str1[10]='',
str2[]={“china”}
strcpy(str1,str2);
这样str1[]数组的内容就是“china”。
扩展资料:
C语言库函数,常用库函数有:
1、scanf格式输入函数
2、printf格式输出函数
3、systemdos命令函数
4、sort排序
5、main主函数
6、fgets文件读取字符串函数
7、fputs文件写入字符串函数
8、fscanf文件格式读取函数
9、fprintf文件格式写入函数
10、fopen打开文件函数
11、getchar输入字符函数
12、putchar输出字符函数
13、malloc动态申请内存函数
参考资料来源:百度百科-函数