在sqlserver环境下,建立一个临时表,表中字段有GNAME和AMT,对应的值是A, 29.33;B, 19.22; C, 25,22; D, 16.79; E, 20.78; F, 25.32。打包的游戏数量限定2个至4个。当包含2个游戏时折扣为9折,3个时8折,4个时6折。问1:计算有多少种(个数)不同的打包组合方式。问2:打包购买游戏时,分别计算出2个打包,3个打包和4个打包时价格最贵的包。
时间: 2024-04-23 08:25:18 浏览: 80
好的,针对你的问题,我来逐一解答:
问1:计算有多少种(个数)不同的打包组合方式。
首先,我们需要先计算出可以组合的游戏数量,即2个、3个或4个。根据题目描述,我们可以知道,由于只有6个游戏,所以最多只能组合4个游戏。那么,可以组合的游戏数量共有多少种情况呢?
对于组合2个游戏,共有C(6,2)种组合方式,即6个游戏中任选2个游戏进行组合。
对于组合3个游戏,共有C(6,3)种组合方式,即6个游戏中任选3个游戏进行组合。
对于组合4个游戏,共有C(6,4)种组合方式,即6个游戏中任选4个游戏进行组合。
因此,不同的打包组合方式总数是C(6,2)+C(6,3)+C(6,4)=15+20+15=50种。
问2:打包购买游戏时,分别计算出2个打包,3个打包和4个打包时价格最贵的包。
首先,我们需要先计算出每种组合方式的价格。由题目描述,我们可以知道,在游戏数量为2个、3个或4个的情况下,价格分别为:
- 组合2个游戏的价格:(29.33+19.22)×0.9=42.11元;
- 组合3个游戏的价格:(29.33+19.22+25.22)×0.8=54.15元;
- 组合4个游戏的价格:(29.33+19.22+25.22+16.79)×0.6=42.11元。
可以看到,组合2个游戏和组合4个游戏的价格是相同的,都是42.11元,而组合3个游戏的价格最贵,为54.15元。
相关问题
func PostPurchaseList(a *decorator.ApiBase, data *adminStruct.PurchaseList) error { logger.AccessLogger.Info("PostPurchaseList....") res := adminStruct.PurchaseListResp{} //res.ResponseCommon = a.NewSuccessResponseCommon() query := a.Ts.Table("purchase_order_info a"). Select("a.poid,a.cuid,a.arrival_num,a.sum_num,a.goods_sum_amt,a.pur_amt,a.other_amt,a.sum_amt,whi.addr,whi.phone,whi.contacts"). Joins(`left join warehouse_info whi on a.wid = whi.wid`) if len(data.OrderNo) > 0 { query = query.Where("a.order_no like ?", fmt.Sprintf("%%%s%%", data.OrderNo)) } if len(data.Sku) > 0 { query = query.Where("gs.sku like ?", fmt.Sprintf("%%%s%%", data.Sku)) } if len(data.Gname) > 0 { query = query.Where("g.gname like ?", data.Gname) } if data.Wid > 0 { query = query.Where("a.wid like ?", data.Wid) } if data.Sid > 0 { query = query.Where("a.sid like ?", data.Sid) } if len(data.LogisticsId) > 0 { query = query.Where("a.logistics_id like ?", data.LogisticsId) } if len(data.Remark) > 0 { query = query.Where("a.remark like ?", data.Remark) } if len(data.ApplyPayStatus) > 0 { query = query.Where("a.arrival_status like ?", data.ApplyPayStatus) } if len(data.PayStatus) > 0 { query = query.Where("a.pay_status like ?", data.PayStatus) } if len(data.ArrivalStatus) > 0 { query = query.Where("a.arrival_status like ?", data.ArrivalStatus) } if data.ArrivalTime > 0 { query = query.Where(" a.arrival_time=?", data.ExpectCime-time.Now().Unix()) } if data.Ctime > 0 { query = query.Where(" a.ctime>=?", data.BeginDate) } if data.Ctime > 0 { query = query.Where(" a.ctime<=?", data.EndDate) } utils.Error(query.Limit(a.Size). Offset(a.Offset). Find(&res.Data).Error) var poids []int64 for _, i := range res.Data { poids = append(poids, i.Poid) } g := []adminStruct.GoodsInfo2{} utils.Error(a.Ts.Table("purchase_order_list b"). Select("b.poid,gs.sku,b.price,b.num,g.gname,g.image,b.polid,b.goods"). Joins(`left join goods_base g on g.gid=b.gid`). Joins(`left join goods_sku gs on gs.gsid = b.skuid`). Where("b.poid in ?", poids).Find(&g).Error) for i, _ := range res.Data { p := &res.Data[i] for _, i2 := range g { if i2.Poid == p.Poid { p.Detail = append(p.Detail, i2) } } } return a.ReturnSuccessCustomResponse(res) }
这段代码是一个名为 "PostPurchaseList" 的函数,它接受两个参数:指向decorator.ApiBase类型的指针a和指向adminStruct.PurchaseList类型的指针data。该函数的目的是根据传入的data参数中的条件查询数据库,并返回查询结果。
首先,函数创建了一个空的adminStruct.PurchaseListResp结构体res,用于存储查询结果。然后,通过调用logger.AccessLogger.Info方法记录日志信息。
接下来,函数创建了一个查询对象query,查询的目标表是"purchase_order_info a",并选择了一些字段。通过左连接warehouse_info表,查询还包括了该表的一些字段。
接下来,函数根据data中的条件逐个添加WHERE子句到query中。如果data中的OrderNo字段不为空,则添加一个类似"a.order_no like '%xxx%'"的条件语句。其他字段的处理方式类似。
然后,函数处理了data中的两个时间字段。如果data中的ArrivalTime字段大于0,则添加一个"a.arrival_time=?"的条件语句,其中参数是data.ExpectCime减去当前时间戳。如果data中的Ctime字段大于0,则添加一个"a.ctime>=?"和"a.ctime<=?"的条件语句,其中参数分别是data.BeginDate和data.EndDate。
接下来,函数通过调用query的Limit和Offset方法设置了查询的限制和偏移量,并将查询结果存储到res.Data中。
接下来,函数创建了一个空的int64类型切片poids,用于存储查询结果中的poid字段。
然后,函数创建了一个空的adminStruct.GoodsInfo2类型切片g,用于存储查询结果中的商品信息。
接下来,函数创建了一个查询对象,查询的目标表是"purchase_order_list b",并选择了一些字段。通过左连接goods_base表和goods_sku表,查询还包括了这两个表的一些字段。其中,查询条件为"b.poid in ?",参数为poids。
最后,函数对查询结果进行处理,将商品信息添加到对应的采购单中。
最后,函数通过调用a的ReturnSuccessCustomResponse方法返回查询结果res。
请注意,这段代码只是函数的实现部分,可能还有其他代码文件中定义的相关结构体、方法等。
select 登录用户.pname,登录用户.gradeid,gname from grade,登录用户 where grade.gid=登录用户.gradeid and pname=?解释一下这个,?是代表啥
这是一个SQL查询语句,用于从数据库中选取登录用户的姓名、所在年级id和年级名称。其中,登录用户表与年级表通过gradeid字段建立了关联。这个查询语句中的问号是一个参数占位符,用于表示需要在查询时动态传入的参数,具体的参数值需要在执行查询时指定。一般情况下,这个问号会被具体的参数值替换掉,以实现动态查询的功能。
阅读全文