-
Notifications
You must be signed in to change notification settings - Fork 0
/
hanshu.h
114 lines (114 loc) · 1.96 KB
/
hanshu.h
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
val vlist[100];
int vweizhi=0;
int nprint=0;
void print(val v);
void printlist(list* l);
void printelement(element* p);
element* transvtoe(val v);
element* newele(val v);
val transetov(element* p);
int vlistpos(char id[]);
void printelement(element* p){
switch(p->type){
case INt:
printf("%d",p->i);break;
case REAl:
printf("%f",p->r);break;
case STRING:
printf("%s",p->str);break;
case LIST:
printlist(p->l);break;
default:
break;
}
}
void printlist(list* l){
element* p;
printf("[");
if (l->len!=0){
p=l->first;
while(p!=NULL){
printelement(p);
printf(",");
p=p->next;
}
}
printf("\b]");
}
void print(val v){
switch(v.type){
case INt:
printf("%d",v.i);break;
case REAl:
printf("%f",v.r);break;
case Id:
printf("%s",v.id);break;
case STRING:
printf("%s",v.str);break;
case LIST:
printlist(v.l);break;
default:
printf("what?");break;
}
}
element* newele(val v){
element* p;
p=(element*)malloc(sizeof(element));
p->type=v.type;
switch(v.type){
case INt:
p->i=v.i;break;
case REAl:
p->r=v.r;break;
case STRING:
strcpy(p->str,v.str);break;
case LIST:
p->l=v.l;break;
default:
break;
}
return p;
}
val transetov(element* p){
val v;
v.type=p->type;
switch(v.type){
case INt:
v.i=p->i;break;
case REAl:
v.r=p->r;break;
case STRING:
strcpy(v.str,p->str);
break;
case LIST:
v.l=p->l;break;
default:
break;
}
return v;
}
element* transvtoe(val v){
element* p;
p=(element*)malloc(sizeof(element));
p->type=v.type;
switch(v.type){
case INt:
p->i=v.i;break;
case REAl:
p->r=v.r;break;
case STRING:
strcpy(p->str,v.str);break;
case LIST:
p->l=v.l;break;
default:
break;
}
return p;
}
int vlistpos(char id[]){
int i;
for(i=0;i<100;i++)
if (strcmp(id,vlist[i].id)==0)
return i;
return -1;
}