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
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
|
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
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
|
-
+
-
+
-
+
-
+
-
+
-
+
-
+
-
-
-
-
-
+
+
+
+
+
-
+
-
+
-
+
-
+
-
-
+
+
-
+
-
+
-
+
-
+
-
-
-
+
+
+
-
+
-
-
+
+
-
-
+
+
-
-
+
+
-
-
-
+
+
+
-
-
-
+
+
+
-
-
-
+
+
+
-
-
-
-
-
-
+
+
+
+
+
+
-
+
-
+
-
+
-
-
+
+
-
-
-
+
+
+
|
local s = {}
local 简文件库 = require("lfs")
local ffi = require("ffi")
--~ 排
--~ 办排中值的能
--~ 入参2
--~ 入参3
--~ 入参4
function s.历排(u1_0, o1, o2, o3, o4)
function s.历排(u1_0, u1, u2, o3, o4)
local k1_0
--~ 集排
k1_0 = {}
for o5 = 1, #u1_0 do
k1_0[#k1_0 + 1] = o1(u1_0[o5], o2, o3, o4)
k1_0[#k1_0 + 1] = u1(u1_0[o5], u2, o3, o4)
end
return k1_0
end
--~ 文
--~ 历文的能
--~ 入参2
--~ 入参3
function s.历文(o1, o2, o3, o4)
function s.历文(u1, u2, o3, o4)
local k1_0
--~ 集排
k1_0 = {}
for o5 in o2(o1, o3, o4) do
for o5 in u2(u1, o3, o4) do
k1_0[#k1_0 + 1] = o5
end
return k1_0
end
--~ 排
--~ 能
function s.历排取一(u1_0, o1)
function s.历排取一(u1_0, u1)
local k1
for o2 = 1, #u1_0 do
for u2 = 1, #u1_0 do
--~ 值
k1 = s.历排取一的模(k1, u1_0[o2], o1)
k1 = s.历排取一的模(k1, u1_0[u2], u1)
end
return k1
end
--~ 值
--~ 排中值
function s.历排取一的模(o1, o2, o3)
if o1 == nil then
return o2
elseif o3(o1, o2) then
return o2
function s.历排取一的模(u1, u2, o3)
if u1 == nil then
return u2
elseif o3(u1, u2) then
return u2
else
return o1
return u1
end
end
--~ 对
--~ 能
function s.历对取一(u1_0, o1)
function s.历对取一(u1_0, u1)
local k1, k2
for o2, u2_0 in pairs(u1_0) do
for u2, u2_0 in pairs(u1_0) do
--~ 键
--~ 值
k1, k2 = s.历对取一的模(k1, k2, o2, u2_0, o1)
k1, k2 = s.历对取一的模(k1, k2, u2, u2_0, u1)
end
return k1, k2
end
function s.历对取一的模(o1, o2, o3, o4, o5)
if o1 == nil then
function s.历对取一的模(u1, u2, o3, o4, o5)
if u1 == nil then
return o3, o4
elseif o5(o1, o2, o3, o4) then
elseif o5(u1, u2, o3, o4) then
return o3, o4
else
return o1, o2
return u1, u2
end
end
function s.历对(u1_0, o1, o2)
function s.历对(u1_0, u1, u2)
local k1
local k1_0, k2_0
--~ 对
k1_0 = {}
for o3, u2_0 in pairs(u1_0) do
--~ 键
--~ 值
k1, k2_0 = o1(o3, u2_0, o2)
k1, k2_0 = u1(o3, u2_0, u2)
if k1 then
k1_0[k1] = k2_0
else
end
end
return k1_0
end
--~ 排中值
--~ 值类
--~ 办值的能
function s.操类(u1_0, o1, o2)
if type(u1_0) == o1 then
return o2(u1_0)
function s.操类(u1_0, u1, u2)
if type(u1_0) == u1 then
return u2(u1_0)
else
return u1_0
end
end
--~ 排中文
--~ 入参2
--~ 入参3
--~ 入参4
function s.全筛文(o1, o2, o3, o4)
function s.全筛文(u1, u2, o3, o4)
print(4)
if string.find(o1, o2, o3, o4) then
return o1
if string.find(u1, u2, o3, o4) then
return u1
end
end
--~ 文
--~ 前缀
function s.加前缀(o1, o2)
return (o2 or "") .. o1
function s.加前缀(u1, u2)
return (u2 or "") .. u1
end
--~ 文
--~ 后缀
function s.加后缀(o1, o2)
return o1 .. (o2 or "")
function s.加后缀(u1, u2)
return u1 .. (u2 or "")
end
--~ 令
function s.办令(o1)
print(o1)
os.execute(o1)
function s.办令(u1)
print(u1)
os.execute(u1)
end
--~ 文
--~ 前缀
function s.全筛前缀(o1, o2)
if string.sub(o1, 1, #o2) == o2 then
return o1
function s.全筛前缀(u1, u2)
if string.sub(u1, 1, #u2) == u2 then
return u1
end
end
--~ 文
--~ 后缀
function s.全筛后缀(o1, o2)
if string.sub(o1, -#o2) == o2 then
return o1
function s.全筛后缀(u1, u2)
if string.sub(u1, -#u2) == u2 then
return u1
end
end
--~ 目对
function s.用令行工具操文件(u1_0)
local k1_9
--~ 令行排
k1_9 = s.历文(u1_0.文件目, 简文件库.dir)
k1_9 = s.历排(k1_9, s.全筛后缀, u1_0.文件类)
for o1 = 1, #k1_9 do
k1_9[o1] = s.加前缀(k1_9[o1], u1_0.文件目)
k1_9[o1] = s.加前缀(k1_9[o1], [["]])
k1_9[o1] = s.加后缀(k1_9[o1], [["]])
k1_9[o1] = s.加前缀(k1_9[o1], u1_0.令行前缀)
s.办令(k1_9[o1])
for u1 = 1, #k1_9 do
k1_9[u1] = s.加前缀(k1_9[u1], u1_0.文件目)
k1_9[u1] = s.加前缀(k1_9[u1], [["]])
k1_9[u1] = s.加后缀(k1_9[u1], [["]])
k1_9[u1] = s.加前缀(k1_9[u1], u1_0.令行前缀)
s.办令(k1_9[u1])
end
end
--~ 文件路
--~ 式
function s.读文件(o1, o2)
function s.读文件(u1, u2)
local k1
local k1_3
--~ 文件
k1_3 = io.open(o1, o2 or "r")
k1_3 = io.open(u1, u2 or "r")
--~ 文
k1 = k1_3:read("a")
k1_3:flush()
k1_3:close()
return k1
end
--~ 常量排
function s.加对限(u1_0)
table.insert(u1_0, 1, "local k1_0 = {}")
table.insert(u1_0, "return k1_0")
return table.concat(u1_0, "\n")
end
--~ 文
--~ 文件路
--~ 式
function s.写文件(o1, o2, o3)
function s.写文件(u1, u2, o3)
local k1_3
--~ 文件
k1_3 = io.open(o2, o3 or "w")
k1_3:write(o1)
k1_3 = io.open(u2, o3 or "w")
k1_3:write(u1)
k1_3:flush()
k1_3:close()
end
--~ 文
function s.删左右空白(o1)
o1 = string.gsub(o1, "^%s+", "")
return string.gsub(o1, "%s+$", "")
function s.删左右空白(u1)
u1 = string.gsub(u1, "^%s+", "")
return string.gsub(u1, "%s+$", "")
end
--~ 对
--~ 对
function s.连两对(u1_0, u2_0)
for u3_0, u4_0 in pairs(u2_0) do
u1_0[u3_0] = u4_0
end
|
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
|
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
|
-
-
+
+
-
-
+
+
-
-
+
+
-
-
+
+
-
-
+
+
-
-
+
+
-
-
+
+
-
-
+
+
-
-
+
+
-
-
+
+
-
-
-
+
+
+
|
function s.递增()
k1 = k1 + 1
return k1
end
end
--~ 左加数
--~ 右加数
function s.加法(o1, o2)
return o1 + o2
function s.加法(u1, u2)
return u1 + u2
end
--~ 左减数
--~ 右减数
function s.减法(o1, o2)
return o1 - o2
function s.减法(u1, u2)
return u1 - u2
end
--~ 左乘数
--~ 右乘数
function s.乘法(o1, o2)
return o1 * o2
function s.乘法(u1, u2)
return u1 * u2
end
--~ 左除数
--~ 右除数
function s.除法(o1, o2)
return o1 / o2
function s.除法(u1, u2)
return u1 / u2
end
--~ 左数
--~ 右数
function s.位和(o1, o2)
return bit.band(o1, o2)
function s.位和(u1, u2)
return bit.band(u1, u2)
end
--~ 数
--~ 右移几位
function s.位右移(o1, o2)
return bit.rshift(o1, o2)
function s.位右移(u1, u2)
return bit.rshift(u1, u2)
end
--~ 键
--~ 最大值
--~ 键
--~ 值
function s.筛对中最大值(o1, o2, o3, o4)
if o2 < o4 then
function s.筛对中最大值(u1, u2, o3, o4)
if u2 < o4 then
return true
end
end
--~ 最短键
--~ 值
--~ 键
--~ 值
function s.筛对中最短键(o1, o2, o3, o4)
if #o1 > #o3 then
function s.筛对中最短键(u1, u2, o3, o4)
if #u1 > #o3 then
return true
end
end
--~ 最短文
--~ 值
function s.筛排中最短文(o1, o2)
if #o1 > #o2 then
function s.筛排中最短文(u1, u2)
if #u1 > #u2 then
return true
end
end
--~ 内数
function s.to_uint64(o1)
local uint64_pointer = ffi.new("uint64_t[1]", o1)
function s.to_uint64(u1)
local uint64_pointer = ffi.new("uint64_t[1]", u1)
return uint64_pointer[0]
end
--~ 键
--~ 值
--~ 要找的值
function s.全等筛对中值(o1, o2, o3)
if o2 == o3 then
return o1, o2
function s.全等筛对中值(u1, u2, o3)
if u2 == o3 then
return u1, u2
else
end
end
return s
|