前言
我是一个职高毕业的程序员,没有读过普高和大学,所以数学比较差,最近因为想搞计算机图形学而要学习一下普高的数学,普高数学有五门必修课和八门选修课,我买了一本《高中数学知识大全》,不过并没有买相关的习题,因为我不为考试,只是为了学习知识,或许基础知识就够用了吧,随便看看书,再用书上的知识写写代码,也就算是练习了。目前我用的是C语言来写代码,在Ubuntu 20.04.2下调试,Linux的编译速度比Win要快的多,当然也可能是我用Linux几乎不开其他程序的关系而在Win下会挂个QQ和浏览器,所以会感觉两者代码编译速度会有很大的差距。不管怎么说我还是喜欢在Linux下搞开发,所以就拿Ubuntu来开发测试了。
集合(一)
集合中的元素的特性:1、确定性;2、互异性;3、无序性。
只不过在计算机中,一个数组的大小是有限的,但在数学中集合的个数允许是无限个,这点会有些出入,其他的基本都好办。
由于数学的大小是有限的,而且需要动态创建,所以这里我使用了stdlib.h中的malloc与free函数,一个创建数组一个销毁数组。
对于互异性,可以在输入完一个元素后比较一下,看看有没有重复的元素,有重复的元素就要求重新输入。
无序性基本不用管,只要用scanf函数接收键盘输入就可以了。
下面上代码:
#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>
int main() {
int count = 0;
printf("请输入集合的大小:");
scanf("%d", &count);
while (count <= 0) {
printf("大小不合法!\n");
printf("请输入集合的大小:");
scanf("%d", &count);
}
int *array = (int*)malloc(sizeof(int) * count);
int index = 0;
bool is_exist;
for (int i = 0; i < count; ++i) {
do {
is_exist = false;
printf("请输入第%d个元素:", i + 1);
scanf("%d", &array[i]);
for (int j = 0; j < index; ++j) {
if (array[i] == array[j]) {
printf("元素已存在!\n");
is_exist = true;
break;
}
}
} while (is_exist);
++index;
}
printf("您输入的元素为:[");
int is_first = 1;
for (int i = 0; i < count; ++i) {
if (is_first) {
is_first = 0;
printf("%d", array[i]);
} else {
printf(" %d", array[i]);
}
}
printf("]\n");
free(array);
return 0;
}