解题思路:

因为本题比较单一,结构比较简单,建议使用链表形式

1】:也可以利用malloc申请空间,就可以到到结构体数组
2】:在设定结构体时,可以在结构体中,定义一个长度为2的数组,用来存储两个数,声请十个空间即可注意事项:



参考代码:

如下有两种解法

1】:

typedef struct stu   //定义结构体
{
  int a[2];         //分别是实部和虚部
}*stu0, stu1;         //省字用的申请


#include#includeint main()
{
    int i = 0;
    int b[2] = { 0 };
    stu0 p = (stu0)malloc(sizeof(stu1) * 10);         //申请相应大小的空间,既可以根据下标进行索引
    for (i = 0; i < 10; i++)
    {
        scanf("%d%d", &p[i].a[0], &p[i].a[1]);       //数据的读入
        b[0] += p[i].a[0];
        b[1] += p[i].a[1];
    }
    printf("%d+%di", b[0], b[1]);
    free(p);                                               //释放空间    
}

2】:首先说明在这里我以p为先,q为后

#include<stdio.h>
#include<malloc.h>
#include<stdlib.h>

typedef struct plural
{
	int a[2];
	struct plural* next;                                    //结构体内的成员,但是由于其类型是该结构体
	                                                        //因此可以用来索引
}*plural0,plural1;



int main()
{
	plural0 p = NULL , q = NULL;
	int i = 1, sum[2] = {0};
	plural0 head = p =  (plural0)malloc(sizeof(plural1));     //这里先要定义一个头
	if (!head)
	{
		printf("There are not enough memery0");
		exit(-1);
	}
	scanf("%d%d", &head->a[0], &head->a[1]);                   //数据读入
	while (i <= 9)
	{
		q = (plural0)malloc(sizeof(plural1));              //空间申请

		scanf("%d%d", &q->a[0], &q->a[1]);
		q->next = NULL;                                    //指针指向
		p->next = q;
		p = q;
		i++;
	}
	p = head;
	while (p)
	{
		sum[0] += p->a[0];
		sum[1] += p->a[1];                       //计算出相应的数值
		p = p->next;
	}
	p = head;
	while(p)
	{
	    free(p);                                     //释放相应的空间
	    p = p->next;
	}
	printf("%d+%di", sum[0], sum[1]);
}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论