在有限多的不大于100的正整数中,找出尽量多个相加起来值介于98~102之间的组合
2008-04-10 12:44
399 查看
问题描述:在有限多的不大于100的正整数中,找出尽量多个相加起来值介于98~102之间的组合。组合的个数限制在2 和3。比如有数字(39,40,1,55,17,17……N)数字可以有重复。找出的组合有(50,50),(21,41,39),(48,50)……M。在上面的数字在组合中每次只能出现一次(比如数字中40只出现过一次,那在组合中也只能出现一次。17出现过两次那在组合中最多两次) 实现现代码-- 测试数据, value 列放要处理的数(此处随机生成100个数据)DECLARE @t TABLE( id int identity, value int)INSERT @t SELECT TOP 100 CHECKSUM(NEWID()) % 100 FROM syscolumns --=====================================================-- 组合处理--=====================================================DECLARE @r TABLE( id int IDENTITY, vs varchar(100))DECLARE @tid TABLE(id int PRIMARY KEY) IF OBJECT_ID('tempdb..#1') IS NOT NULL DROP TABLE #1SELECT id1 = A.id, value1 = A.value, id2 = B.id, value2 = B.value, value = A.value + B.value, flag = CASE WHEN A.value + B.value BETWEEN 98 AND 102 THEN 1 ELSE 0 ENDINTO #1FROM @t A, @t BWHERE A.id < B.id DECLARE tb CURSOR STATIC LOCALFORSELECT id1, id2, id3, vsFROM( -- 二次组合的 SELECT flag = 2, A.id1, A.id2, id3 = NULL, vs = RTRIM(A.value1) + ',' + RTRIM(A.value2) FROM #1 A WHERE flag = 1 UNION ALL -- 三次组合的 SELECT flag = 3, A.id1, A.id2, id3 = B.id, RTRIM(A.value1) + ',' + RTRIM(A.value2) + ',' + RTRIM(B.value) FROM #1 A, @t B WHERE A.id2 < B.id AND A.value + B.value BETWEEN 98 AND 102)AORDER BY flag DESC -- 仅选出复合需求的数据(过滤重复数据)DECLARE @id1 int, @id2 int, @id3 int, @values varchar(100)OPEN tbFETCH tb INTO @id1, @id2, @id3, @valuesWHILE @@ROWCOUNT > 0BEGIN IF NOT EXISTS( SELECT * FROM @tid WHERE id IN(@id1, @id2, @id3)) BEGIN INSERT @r VALUES(@values) INSERT @tid SELECT * FROM( SELECT id = @id1 UNION ALL SELECT @id2 UNION ALL SELECT @id3 )A WHERE id > 0 END FETCH tb INTO @id1, @id2, @id3, @valuesENDCLOSE tbDEALLOCATE tb -- 显示结果SELECT vs FROM @r
相关文章推荐
- [导入]在有限多的不大于100的正整数中,找出尽量多个相加起来值介于98~102之间的组合
- 在有限多的不大于100的正整数中,找出尽量多个相加起来值介于98~102之间的组合
- 在有限多的不大于100的正整数中,找出尽量多个相加起来值介于98~102之间的组合
- 在有限多的不大于100的正整数中,找出尽量多个相加起来值介于98~102之间的组合
- 在有限多的不大于100的正整数中,找出尽量多个相加起来值介于98~102之间的组合
- 在有限多的不大于100的正整数中,找出尽量多个相加起来值介于98~102之间的组合
- 在有限多的不大于100的正整数中,找出尽量多个相加起来值介于98~102之间的组合
- 在有限多的不大于100的正整数中,找出尽量多个相加起来值介于98~102之间的组合
- 在有限多的不大于100的正整数中,找出尽量多个相加起来值介于98~102之间的组合
- 在有限多的不大于100的正整数中,找出尽量多个相加起来值介于98~102之间的组合
- 在有限多的不大于100的正整数中,找出尽量多个相加起来值介于98~102之间的组合
- 在有限多的不大于100的正整数中,找出尽量多个相加起来值介于98~102之间的组合
- 在有限多的不大于100的正整数中,找出尽量多个相加起来值介于98~102之间的组合
- 在有限多的不大于100的正整数中,找出尽量多个相加起来值介于98~102之间的组合
- 在有限多的不大于100的正整数中,找出尽量多个相加起来值介于98~102之间的组合
- 编程实现求出若干个整数之和为500的连续整数(如98,99,100,101,102),所有组合。
- 实现求出若干整数之和为500的连续整数(如98,99,100,101,102)的所有组合&&产生一个int数组,长度为100,并向其中随机插入1~100,要求不能重复
- 输入一个整数,如果该整数大于1000,则输出“big”,如果该整数介于100到1000之间(包含两个边界),则输出“middle”,如果上面两种情况都不满足,输出”small“
- 输入一个整数,如果该整数大于1000,则输出“big”,如果该整数介于100到1000之间(包含两个边界),则输出“middle”,如果上面两种情况都不满足,输出”small“
- 输入一个整数,如果该整数大于1000,则输出“big”,如果该整数介于100到1000之间(包含两个边界),则输出“middle”,如果上面两种情况都不满足,输出”small“