-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnopriority.c
145 lines (137 loc) · 4.45 KB
/
nopriority.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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
#include<stdio.h>
#include<stdlib.h>
#include<stdbool.h>
#define NUM 30
#define LENGTH 50
#define TRUE 1
#define FALSE 0
typedef struct LNODE{
int level;
_Bool *flag;
float result;
struct LNODE *next;
}LinkNode, *PLinkNode;
typedef struct LList{
PLinkNode head;
PLinkNode rear;
}LinkList, *PLinkList;
void InitList(PLinkList Queue);
void InsertRear(PLinkList Queue, PLinkNode NewNode);
int IsEmpty(PLinkList Queue);
PLinkNode DeleteHead(PLinkList Queue);
int find(PLinkList Queue, PLinkNode NewNode, int count, int n);
int search(int n, int m, int *Number);
int main(void){
int i, n, m, k = 0;
int Input[NUM][2], NumberSet[NUM][LENGTH];
while (scanf("%d%d", &n, &m) != EOF && m + n !=0){
Input[k][0] = n;
Input[k][1] = m;
for (i = 0; i < n; i++) scanf("%d", &NumberSet[k][i]);
k++;
}
for (i = 0; i < k; i++){
n = Input[i][0];
m = Input[i][1];
int min = search(n, m, NumberSet[i]);
if(min == -1) printf("No Solution!\n");
else printf("%d\n", min);
}
return 0;
}
int search(int n, int m, int *Number){
int i, j, k = 0, r = 0, count = 0;
PLinkList Queue = (PLinkList)malloc(sizeof(LinkList));
InitList(Queue);
for (i = 0; i < n; i++){
if (Number[i] == m) return 0;
PLinkNode Node = (PLinkNode)malloc(sizeof(LinkNode));
_Bool *Frag = (_Bool *)malloc(n * sizeof(_Bool));
for (j = 0; j < n; j++) Frag[j] = 0;
Frag[i] = 1;
Node->flag = Frag;
Node->level = 0;
Node->result = Number[i];
InsertRear(Queue, Node);
}
while (!IsEmpty(Queue)){
PLinkNode temp = DeleteHead(Queue);
if(k + 1 == temp->level){
k = temp->level;
count = 0;
}
if (temp->level < n ){
for (i = 0; i < n; i++){
_Bool *Frag = temp->flag;
if (!Frag[i]){
for (j = 0; j < 4; j++){
PLinkNode NewNode = (PLinkNode)malloc(sizeof(LinkNode));
switch (j){
case 0: NewNode->result = temp->result + Number[i];break;
case 1: NewNode->result = temp->result - Number[i];break;
case 2: NewNode->result = temp->result * Number[i];break;
case 3: NewNode->result = temp->result / Number[i];break;
default: break;
}
if(NewNode->result == m) {
free(NewNode);
return temp->level + 1;
}
_Bool *newFrag = (_Bool *)malloc(n * sizeof(_Bool));
for (r = 0; r < n; r++) newFrag[r] = Frag[r];
newFrag[i] = 1;
NewNode->flag = newFrag;
NewNode->level = temp->level + 1;
if (k < 1){
if (!find(Queue, NewNode, count, n)){
InsertRear(Queue, NewNode);
count++;
}
else free(NewNode);
}
else InsertRear(Queue, NewNode);
}
}
}
}
free(temp->flag);
free(temp);
}
return -1;
}
int find(PLinkList Queue, PLinkNode NewNode, int count, int n){
int i, j;
PLinkNode cur = Queue->head->next;
for (i = 0; i < count; i++){
if (NewNode->result == cur->result){
_Bool *Frag1 = NewNode->flag;
_Bool *Frag2 = cur->flag;
for (j = 0; j < n; j++){
if (Frag1[j] != Frag2[j]) break;
}
if (j >= n) return TRUE;
}
cur = cur->next;
}
return FALSE;
}
void InitList(PLinkList Queue){
PLinkNode HeadNode = (PLinkNode)malloc(sizeof(LinkNode));
Queue->head = Queue->rear = HeadNode;
if (Queue->head == NULL) exit(-1);
}
void InsertRear(PLinkList Queue, PLinkNode NewNode){
Queue->rear->next = NewNode;
Queue->rear = NewNode;
NewNode->next = NULL;
}
int IsEmpty(PLinkList Queue){
if(Queue->head == Queue->rear) return TRUE;
else return FALSE;
}
PLinkNode DeleteHead(PLinkList Queue){
PLinkNode temp = (PLinkNode)malloc(sizeof(LinkNode));
temp = Queue->head->next;
Queue->head = Queue->head->next;
return temp;
}