-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy path10.c
72 lines (58 loc) · 1.26 KB
/
10.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
#include <stdio.h>
#include <stdlib.h>
struct vector
{
int *elements;
int size;
};
struct vector createVector(int size)
{
struct vector v;
v.elements = (int *)malloc(size * sizeof(int));
v.size = size;
return v;
}
struct vector addVectors(struct vector v1, struct vector v2)
{
struct vector result;
result.size = v1.size;
result.elements = (int *)malloc(result.size * sizeof(int));
for (int i = 0; i < result.size; i++)
{
result.elements[i] = v1.elements[i] + v2.elements[i];
}
return result;
}
void displayVector(struct vector v)
{
printf("(");
for (int i = 0; i < v.size; i++)
{
printf("%d", v.elements[i]);
if (i != v.size - 1)
printf(", ");
}
printf(")\n");
}
int main()
{
struct vector v1 = createVector(5);
struct vector v2 = createVector(5);
struct vector result;
v1.elements[0] = 1;
v1.elements[1] = 2;
v1.elements[2] = 3;
v1.elements[3] = 4;
v1.elements[4] = 5;
v2.elements[0] = 6;
v2.elements[1] = 7;
v2.elements[2] = 8;
v2.elements[3] = 9;
v2.elements[4] = 10;
result = addVectors(v1, v2);
displayVector(result);
free(v1.elements);
free(v2.elements);
free(result.elements);
return 0;
}