-
Notifications
You must be signed in to change notification settings - Fork 2.4k
/
Copy path1046-last-stone-weight.c
84 lines (76 loc) · 1.96 KB
/
1046-last-stone-weight.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
73
74
75
76
77
78
79
80
81
82
83
84
#include <stdio.h>
#include <stdlib.h>
int lastStoneWeight(int *stones, int stonesSize) {
while (stonesSize > 1) {
// Find indices of the two largest stones
int max1 = 0, max2 = 1;
if (stones[max2] > stones[max1]) {
int temp = max1;
max1 = max2;
max2 = temp;
}
for (int i = 2; i < stonesSize; i++) {
if (stones[i] > stones[max1]) {
max2 = max1;
max1 = i;
} else if (stones[i] > stones[max2]) {
max2 = i;
}
}
// Smash the stones and update the array
if (stones[max1] != stones[max2]) {
stones[max1] -= stones[max2];
stones[max2] = 0;
} else {
stones[max1] = 0;
stones[max2] = 0;
}
// Remove the smashed stones
int newSize = 0;
for (int i = 0; i < stonesSize; i++) {
if (stones[i] != 0) {
stones[newSize++] = stones[i];
}
}
stonesSize = newSize;
}
return (stonesSize == 0) ? 0 : stones[0];
}
/*
int extractMax(int* stones, int stonesSize) {
int max = stones[0];
for (int i = 1; i < stonesSize; i++) {
if (stones[i] > max) {
max = stones[i];
}
}
for (int i = 0; i < stonesSize; i++) {
if (stones[i] == max) {
stones[i] = 0;
break;
}
}
return max;
}
void insert(int* stones, int stonesSize, int value) {
for (int i = 0; i < stonesSize; i++) {
if (stones[i] == 0) {
stones[i] = value;
return;
}
}
}
int lastStoneWeight(int* stones, int stonesSize) {
while (1) {
int y = extractMax(stones, stonesSize);
int x = extractMax(stones, stonesSize);
if (x == 0) {
return y;
}
if (x != y) {
insert(stones, stonesSize, y - x);
}
}
return 0;
}
*/