我不想使用string.reverse()
而是想创建自己的方式。但我失败了。
我哪里出错:
function wait(n)
local now = os.time()
while os.time() - now < n do end
end
sit = "1234 1234"
function revers(sit)
wait(1)
local table = { " nil "}
print(#sit, os.date("%M"))
while #table < #sit do
table.insert(table, #table+1, sit:find(".", #sit))
print(#table, #sit)
wait(1)
end
end
revers(sit)
答案 0 :(得分:3)
很抱歉,但您的代码存在一些基本问题:
revers
不会返回任何内容revers
仅尝试构建表,而不是字符串nil
,无论是键还是值sit:find(".",#sit)
使用了错误的常量起点尝试了解应该执行此操作的以下代码:
function revers(s)
local r = ""
for i = 1,#s,1 do
r = s:sub(i,i) .. r
end
return r
end
答案 1 :(得分:0)
问题是
local table = { " nil " }
您不能在保留字后命名变量。如果将其更改为
local mytable = { " nil " }
同时更改所有后续用途:
function wait(n)
local now = os.time()
while os.time() - now < n do end
end
sit = "1234 1234"
function revers(sit)
wait(1)
local mytable = { " nil "}
print(#sit, os.date("%M"))
while #mytable < #sit do
mytable.insert(mytable, #mytable+1, sit:find(".", #sit))
print(#mytable, #sit)
wait(1)
end
end
revers(sit)
更简单的方法是:
function revers(sit)
local mytable = { " nil "}
for i = 0, #sit+1 do
table.insert(mytable, string.sub(sit, #sit-i, #sit-i))
end
end
该表现在包含相反顺序的字符串字符数组。
答案 2 :(得分:0)
您应该尝试遍历sit
中的每个字符并将其写入table
。尝试使用此代替while
循环
for c in str:gmatch"." do
table.insert(table,c)
-- or
table = table .. c -- the table shouldn't be initialized nil in this case
end
答案 3 :(得分:0)
这会将数组复制一个值&#34; Wednesday&#34;以相反的顺序排列b。
#include <stdio.h>
main()
{
char a[] = "Wednesday";
char b[12];
char *a_ptr, *b_ptr;
int lkm = 0; /* number of characters */
int i = 0;
while(a[i] != '\0')
{
i++;
lkm++;
}
lkm = lkm - 1;
a_ptr = a;
b_ptr = b;
a_ptr += lkm;
int j;
for(j = lkm; j >= 0; j--)
{
*b_ptr = *a_ptr;
a_ptr--;
b_ptr++;
}
fprintf(stdout, "Before: %s\n", a);
fprintf(stdout, "After: %s\n", b);
return(0);
}
Program output:
Before: Wednesday
After: yadsendeW
&#13;