Add pset4

This commit is contained in:
juan 2022-10-30 20:57:06 +08:00
parent e23ed8daa6
commit a4f5a82f7e
No known key found for this signature in database
GPG key ID: 5C1E5093C74F1DC7
5 changed files with 213 additions and 3 deletions

View file

@ -111,6 +111,7 @@ list *adjust(list *li) {
j++; j++;
k++; k++;
} else if (li->arr[i]->degree == li->arr[j]->degree) { } else if (li->arr[i]->degree == li->arr[j]->degree) {
// remember, no need to do anything else.
li->arr[i] = merge(li->arr[i], li->arr[j]); li->arr[i] = merge(li->arr[i], li->arr[j]);
erase(li, j); erase(li, j);
} }

View file

@ -0,0 +1,146 @@
#include <stdio.h>
#include <stdlib.h>
#define MAX 10000
typedef struct treeNode {
char val;
int freq;
struct treeNode *left, *right;
} treeNode;
typedef struct heap {
int size;
treeNode **arr;
} heap;
heap *newHeap() {
heap *h = malloc(sizeof(heap));
h->size = 0;
h->arr = malloc(sizeof(treeNode *) * MAX);
return h;
}
int parent(int i) { return (i - 1) / 2; }
int left(int i) { return i * 2 + 1; }
int right(int i) { return i * 2 + 2; }
void swapNode(treeNode **l, treeNode **r) {
treeNode *tmp = *l;
*l = *r;
*r = tmp;
}
void insert(heap *h, treeNode *val) {
int i = h->size++;
h->arr[i] = val;
while (h->arr[i]->freq < h->arr[parent(i)]->freq) {
swapNode(&h->arr[i], &h->arr[parent(i)]);
i = parent(i);
}
}
void heapify(heap *h, int i) {
// from up to down.
int smallest = i;
int l = left(i), r = right(i);
// Check for OOB!!!!!!
if (l < h->size && h->arr[smallest]->freq > h->arr[l]->freq) {
smallest = l;
}
if (r < h->size && h->arr[smallest]->freq > h->arr[r]->freq) {
smallest = r;
}
if (smallest != i) {
swapNode(&h->arr[i], &h->arr[smallest]);
heapify(h, smallest);
}
}
treeNode *extractMin(heap *h) {
treeNode *res = h->arr[0];
// printf("Poped: %c %d\n", res->val, res->freq);
h->arr[0] = h->arr[h->size - 1];
h->size--;
heapify(h, 0);
return res;
}
treeNode *newNode(char val, int freq) {
treeNode *n = malloc(sizeof(treeNode));
n->freq = freq;
n->val = val;
n->left = n->right = NULL;
return n;
}
treeNode *buildHuffmanTree(heap *h) {
while (h->size != 1) {
treeNode *l = extractMin(h);
treeNode *r = extractMin(h);
treeNode *new = newNode('#', l->freq + r->freq);
new->left = l;
new->right = r;
insert(h, new);
}
return extractMin(h);
}
int isLeaf(treeNode *tr) { return (!tr->left) && (!tr->right); }
void printCode(treeNode *tr, char *input) {
treeNode *ptr;
int top = 0;
while (input[top] != '\n' && input[top] != '\0') {
ptr = tr;
while (!isLeaf(ptr)) {
if (input[top] == '0') {
// printf("%c", input[top]);
ptr = ptr->left;
top++;
} else if (input[top] == '1') {
// printf("%c", input[top]);
ptr = ptr->right;
top++;
}
}
// printf(":%c\n", ptr->val);
printf("%c", ptr->val);
}
}
void printTree(treeNode *tr) {}
int main(void) {
heap *h = newHeap();
insert(h, newNode('a', 7));
insert(h, newNode('b', 19));
insert(h, newNode('c', 2));
insert(h, newNode('d', 6));
insert(h, newNode('e', 32));
insert(h, newNode('f', 3));
insert(h, newNode('g', 21));
insert(h, newNode('h', 10));
treeNode *huffmanTree = buildHuffmanTree(h);
char input[MAX];
fgets(input, MAX, stdin);
printCode(huffmanTree, input);
return 0;
}

View file

@ -0,0 +1,27 @@
#include <stdio.h>
#include <stdlib.h>
void insert(long long *box, long long val, int i) {
int loc = (val + i * i) % 10;
if (loc < 10 && box[loc] == 0) {
box[loc] = val;
} else {
insert(box, val, i + 1);
}
}
int main(void) {
long long box[10] = {};
long long phone;
while (scanf("%lld,", &phone) != EOF) {
insert(box, phone, 0);
}
for (int i = 0, size = 10; i < size - 1; i++) {
printf("%lld,", box[i]);
}
printf("%lld", box[9]);
return 0;
}

View file

@ -0,0 +1,36 @@
#include <iostream>
#include <unordered_map>
#include <cstdio>
#pragma GCC optimize("Ofast")
using namespace std;
int main(void) {
int size, minMile;
unordered_map<string, int> data;
scanf("%d%d", &size, &minMile);
// cout << size << ' ' << minMile << '\n';
char id_char[18];
string id;
int tmp;
for (int i = 0; i < size; i++) {
scanf("%s%d", id_char, &tmp);
id = id_char;
data[id] += max(tmp, minMile);
}
int queries;
scanf("%d", &queries);
for (int i = 0; i < queries; i++) {
scanf("%s", id_char);
id = id_char;
if (data.find(id) == data.end()) {
printf("No Info\n");
} else {
printf("%d\n", data[id]);
}
}
return 0;
}