对lua表中数据按一定格式处理,循环

时间:2023-01-15 12:53:10
function putStartCard(handCard)
function dataDeal(array,a,b,c)
cclog("进入datadeal====================================")
for i=,#array do
cclog("array[%d]======%d",i,array[i])
end
local result = {}
if #array >= then
for i=,#array do
if a == array[i] then
for j=i+, #array do
if b == array[j] then
for k=j+,#array do
if c == array[k] then
table.insert(result,array[i])
table.insert(result,array[j])
table.insert(result,array[k])
cclog("%d,%d,%d",array[i],array[j],array[k])
table.remove(array,k)
table.remove(array,j)
table.remove(array,i)
cclog("找到2,7,10===============")
cclog("result===%d%d%d",result[],result[],result[])
for ii=,#array do
cclog("array[%d]=======%d",ii,array[ii])
end
return result
end
end
end
end
end
end
end
cclog("没找到2,7==============")
return result
end local unUseless =
local i = nil
local data = {}
for j=, do
data[j] = {}
end for i=, do
for j=, -i do
if handCard[j] > handCard[j+] then
handCard[j],handCard[j+] = handCard[j+],handCard[j]
end
end
end
cclog("排序后的数据")
for i=, do
cclog("handCard[%d]===============%d",i,handCard[i])
end i =
repeat
if handCard[i] == handCard[i+] and handCard[i] == handCard[i+] and
handCard[i] == handCard[i+] then
cclog("进入data1")
for j=, do
table.insert(data[],handCard[i])
end
cclog("data[i]====%d,%d,%d,%d",data[][],data[][],data[][],data[][]) i = i+
elseif handCard[i] == handCard[i+] and handCard[i] == handCard[i+] then
cclog("进入data2")
for j=, do
table.insert(data[],handCard[i])
end
i = i+ elseif handCard[i] == handCard[i+] then
cclog("进入data3")
for j=, do
table.insert(data[],handCard[i])
end
i = i+
else
cclog("进入data4")
table.insert(data[],handCard[i])
i = i+
end
until(i>) cclog("第二次处理后的数据")
for i=, do
for j=,#data[i] do
cclog("data[%d][%d]=====%d",i,j,data[i][j])
end
end
---------------------------------------------------------------------
--从表中选出,想要的三个数据
function dataInsert(table1,table2)
for i=, #table2 do
table.insert(table1,table2[i])
end
end
cclog("开始查找2710===========")
dataInsert(data[],dataDeal(data[],,,))
dataInsert(data[],dataDeal(data[],,,))
dataInsert(data[],dataDeal(data[],,,))
for i=, do
dataInsert(data[],dataDeal(data[],i,i+,i+))
end return data
end
--用于测试
handCard = {,,,,,,,,,,,,,,,,,,,}
local aa = putStartCard(handCard)
cclog("aaaaaaaaaaaaaaaaaaaaaaaaaaaa")
for i=, do
for j=,#aa[i] do
cclog("aa[%d][%d]=======%d",i,j,aa[i][j])
end
end
cclog("aaaaaaaaaaaaaaaaaaaaaaaaaaaa")

将表handCard中数据分为四组4个(相同的数据),3个(同样的数据and2,7,10and顺子),两个(相同的数据),一个(里边有很多数据,但没有重复的,没有顺子)
注意:1.表中数据移除,不可用{}和nil,移除时,表中数据会左移

    2.表中数据插入,插入的是单个数据

3.repeat循环不可以更改为for循环,for i=1,10 do end 中i只是指定循环次数

      例如:for i=1, 10 do

          i = i+3

          cclog("%d",i)

         end

        输出:4,5,6,7,8,9,10,11,12,13

        上边for循环中的i值失效

4.lua中没有continue导致程序循环次数过多

对lua表中数据按一定格式处理,循环的更多相关文章

  1. Oracle中使用游标转换数据表中指定字段内容格式(拼音转数字)

    应用场景:将数据表TB_USER中字段NNDP的内容中为[sannanyinv]转换为[3男1女] 主要脚本:一个游标脚本+分割字符串函数+拼音转数字脚本 操作步骤如下: 1.创建类型 create ...

  2. MySQL查询数据表中数据记录(包括多表查询)

    MySQL查询数据表中数据记录(包括多表查询) 在MySQL中创建数据库的目的是为了使用其中的数据. 使用select查询语句可以从数据库中把数据查询出来. select语句的语法格式如下: sele ...

  3. mysql--对行(表中数据)的增删改查

    一.插入数据(增加)insert 1.插入数据(顺序插入) 语法一: INSERT INTO 表名(字段1,字段2,字段3…字段n) VALUES(值1,值2,值3…值n); #指定字段来插入数据,插 ...

  4. jmeter随笔(1)-在csv中数据为json格式的数据不完整

    昨天同事在使用jmeter遇到问题,在csv中数据为json格式的数据,在jmeter中无法完整的取值,小怪我看了下,给出解决办法,其实很简单,我们一起看看,看完了记得分享给你的朋友. 问题现象: 1 ...

  5. Oracle 取两个表中数据的交集并集差异集合

    Oracle 取两个表中数据的交集 关键字: Oracle 取两个表中数据的交集 INTERSECT Oracle 作为一个大型的关系数据库,日常应用中往往需要提取两个表的交集数据 例如现有如下表,要 ...

  6. Mysql清空表(truncate)与删除表中数据(delete)的区别

    来源:http://blog.is36.com/mysql_difference_of_truncate_and_delete/ 为某基于wordpress搭建的博客长久未除草,某天升级的时候发现已经 ...

  7. db2删除表中数据

    DB2数据库系统建表后,难免会有将表中数据清空的需求,本文将为您介绍DB2数据库中四种数据删除的方法,供您参考,您可以根据实际情况来进行选择,希望能对有所帮助. 1. 使用 DELETE 语句,即: ...

  8. mysql利用navicat导出表结构和表中数据

    LZ在网上搜索了要如何导出mysql的表结构和表中数据,发现有的方法不好用 记录一下好用的方式: 用navicat打开DB链接后,点击数据库,右击选择转储SQL文件,然后选择结构和数据: 之后弹出新的 ...

  9. pl/sql中误删表中数据并提交恢复办法

    最近在操作表中数据时,删除了表中数据,但是又想恢复,后来查到了官方的一篇文档,发现还蛮有用的,如下: 在pl/sql中运行,select * from A as of TIMESTAMP to_tim ...

随机推荐

  1. C# DateTime日期格式化

    在C#中DateTime是一个包含日期.时间的类型,此类型通过ToString()转换为字符串时,可根据传入给Tostring()的参数转换为多种字符串格式. 目录 1. 分类 2. 制式类型 3. ...

  2. Tomcat 日志清除(含扩展AccessLogValve)

    1.tomcat的访问日志AccessLogs定期或者定量删除 a 开启tomcat访问日志 编辑${catalina}/conf/server.xml文件.注:${catalina}是tomcat的 ...

  3. Win10安装程序出现error code 2502 2503

    在Win10中,在安装msi安装包的时候常常会出现代码为2502.2503的错误.其实这种错误是由于安装权限不足造成的,可以这种msi的安装包不像其他exe的安装程序,在安装包上点击"右键& ...

  4. Android 如何实现带滚动条的TextView,在更新文字时自动滚动到最后一行?

    1.在布局文件中放置一个TextView,给它添加scrollbars和fadeScrollbars两个属性. 如下设置:滚动条为垂直滚动条,并且一直可见(当TextView中的文字行数超过页面能显示 ...

  5. squid 学习笔记

    Squid学习笔记 1.安装前的配置 编译安装之前需要校正的参数主要包括File Descriptor和Mbuf Clusters. 1.File Descriptor 查看文件描述符的限制数目: u ...

  6. UI5_UIAlertView与UIActionSheet

    // // ViewController.h // UI5_UIAlertView与UIActionSheet // // Created by zhangxueming on 15/7/7. // ...

  7. [转载]C#获取本机IPv4地址

    C#获取本机IP地址在C#1.0之后都使用下面的这种形式: IPHostEntry ipe = Dns.GetHostEntry(Dns.GetHostName()); IPAddress ipa=i ...

  8. oracle 高水位线

    一.oracle 高水位线详解 一.什么是水线(High Water Mark)? 概念: 1.块: 是粒度最小的存储单位,现在标准的块大小是8K,ORACLE每一次I/O操作也是按块来操作的,也就是 ...

  9. 关于Visual Studio中的TraceDebugging文件夹

    最近一段时间发现C盘莫名其妙的变小了,各种清理各种卸载还是没用,电脑慢的是在无法使用 .最后只能一个文件夹一个文件夹的找,最后针对“C:\Documents and Settings\All User ...

  10. 解析令人费解的java泛型

    对于我们java中的泛型,可能很多人知道怎么使用并且使用的还不错,但是我认为想要恰到好处的使用泛型,还是需要深入的了解一下它的各种概念和内部原理.本文将尽可能的囊括java泛型中的重要的概念.主要内容 ...