1、编写一个函数,把两个数组中相对应的元素相加,然后把结果存储到第3个数组中。也就是说,如果数组1中包含的值是2、4、5、8,数组2中包含的值是1、0、4、6,那么该函数把3、4、9、14赋给第3个数组。函数的参数包含三个数组名和数组大小,并在主函数中调用调试。
#include <stdio.h>
void count(int *p1,int *p2,int *p3,int x);
int main()
{
int arr01[4]={2,4,5,8};
int arr02[4]={1,0,4,6};
int arr03[4];
count(arr01,arr02,arr03,4);
}
void count(int *p1,int *p2,int *p3,int x)
{
int i;
for(i=0;i<x;i++)
{
*(p3+i) = (*(p1+i))+ (*(p2+i));
}
printf("两个数组对应各元素和分别为:\n");
for(i=0;i<x;i++)
{
printf("%d ",p3[i]);
}
}
2.利用内存分配函数malloc,开辟出一块连续空间,依次保存字母a-z,A-Z;
打印输出后,再进行逆序打印输出z-a,Z-A
#include <stdio.h>
#include <malloc.h>
int main()
{
char *p01=(char *) malloc(sizeof(char)*26);
char *p02=(char *) malloc(sizeof(char)*26);
int i;
printf("大写字母顺序输出:\n");
for(i=0;i<26;i++)
{
*(p01+i)=('A'+i);
printf("%c ",*(p01+i));
}
printf("\n\n");
printf("小写字母顺序输出:\n");
for(i=0;i<26;i++)
{
*(p02+i)=('a'+i);
printf("%c ",*(p02+i));
}
printf("\n\n");
printf("大写字母反序输出:\n");
for(i=25;i>=0;i--)
{
printf("%c ",*(p01+i));
}
printf("\n\n");
printf("小写字母反序输出:\n");
for(i=25;i>=0;i--)
{
printf("%c ",*(p02+i));
}
return 0;
}
运行结果: