c语言抽象数据类型-复数

设计一个可进行复数运算的演示程序,要求实现下列四种基本运算:

1)由输入的实部和虚部生成一个复数;

2)两个复数求和;

3)两个复数求差;

4)两个复数求积;

5)打印输出一个复数。

复制代码
#include <stdio.h>
typedef struct {
	float x;
	float y;
} complex;
void creat(complex* c);
void outputc(complex a);
complex add(complex k, complex h);
complex sub(complex k, complex h);
complex chengji(complex k, complex h);
complex a, b, a1;
int cmd;
int main() {
	creat(&a);
	outputc(a);
	creat(&b);
	outputc(b);
	printf("相加");
	a1 = add(a, b);
	outputc(a1);
	printf("相减");
	a1 = sub(a, b);
	outputc(a1);
	printf("相乘");
	a1 = chengji(a, b);
	outputc(a1);
	return 0;
}
void creat(complex* c)
{
	float x1, y1;
	printf("\n输入实部 x = ");
	scanf_s("%f", &x1);
	printf("\n输入虚部 y = ");
	scanf_s("%f", &y1);
	c->x = x1;
	c->y = y1;
}

void outputc(complex a)
{
	printf("复数: %lf + %lfi\n", a.x, a.y);
}
complex add(complex k, complex h)
{
	complex l;
	l.x = k.x + h.x;
	l.y = k.y + h.y;
	return l;
}
complex sub(complex k, complex h)
{
	complex l;
	l.x = k.x - h.x;
	l.y = k.y - h.y;
	return l;
}
complex chengji(complex k, complex h)
{
	complex l;
	l.x = k.x * h.x - k.y * h.y;
	l.y = k.x * h.y + k.y * h.x;
	return l;
}
相关推荐
冠位观测者4 小时前
【Leetcode 每日一题】2900. 最长相邻不相等子序列 I
数据结构·算法·leetcode
努力写代码的熊大4 小时前
链表的中间结点数据结构oj题(力扣876)
数据结构·leetcode·链表
y102121044 小时前
Pyhton训练营打卡Day27
java·开发语言·数据结构
daiwoliyunshang4 小时前
哈希表实现(1):
数据结构·c++
GG不是gg4 小时前
排序算法之高效排序:快速排序,归并排序,堆排序详解
数据结构·算法·排序算法
GG不是gg4 小时前
排序算法之线性时间排序:计数排序,基数排序,桶排序详解
数据结构·算法·排序算法
越城4 小时前
深入理解二叉树:遍历、存储与算法实现
c语言·数据结构·算法
Hygge-star5 小时前
【数据结构】二分查找-LeftRightmost
java·数据结构·算法
努力的小帅5 小时前
C++_STL_map与set
开发语言·数据结构·c++·学习·leetcode·刷题
与己斗其乐无穷5 小时前
数据结构(3)线性表-链表-单链表
数据结构·链表