一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Sql Server - SQL計算字符串中最大的遞增子序列的方法

SQL計算字符串中最大的遞增子序列的方法

2020-07-15 18:38Boss_he Sql Server

這篇文章主要講述了在SQL SERVER 2005中求解一組字符串的最大遞增子序列的方法,需要的朋友可以參考下

求字符串中最大的遞增子序列

數據庫環境:SQL SERVER 2005

如題,求字符串“abcbklmnodfghijkmer”中最大的遞增子序列。這個字符串有點特別,

只由26個小寫字母a-z組成。

大概思路如下:

1.將字符串轉到一列存儲,并生成行號

2.設置一個遞增計數器列,默認為1,比較上下行的字符,如果在字典中的順序是遞增,

則計數器加1,否則,計數器置1

3.找出計數器最大的數及對應的行號,根據這2個數截取字符串

思路有了,下面直接貼代碼

?
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
DECLARE @vtext VARCHAR(255)
SET @vtext = 'abcbklmnodfghijkmer'
/*講字符串轉成一列存儲,并生成行號*/
WITH x0
   AS ( SELECT number AS id ,
      SUBSTRING(@vtext, number, 1) AS letter
    FROM  master.dbo.spt_values
    WHERE type = 'P'
      AND number <= LEN(@vtext)
      AND number >= 1
    ),/*實現計數器*/
  x1 ( id, letter, clen )
   AS ( SELECT id ,
      letter ,
      1 AS clen
    FROM  x0
    WHERE id = 1
    UNION ALL
    SELECT x0.id ,
      x0.letter ,
      CASE WHEN x1.letter <= x0.letter THEN x1.clen + 1
        ELSE 1
      END AS clen
    FROM  x0 ,
      x1
    WHERE x0.id = x1.id + 1
    )
 /*截取字符串*/
 SELECT SUBSTRING(@vtext, start, sublen) AS 最大子序列
 FROM ( SELECT id ,
      clen ,
      MAX(clen) OVER ( ) AS maxclen ,
      id - MAX(clen) OVER ( ) + 1 AS start ,
      MAX(clen) OVER ( ) AS sublen
    FROM  x1
   ) t
 WHERE clen = maxclen

求出的最大子序列是

SQL計算字符串中最大的遞增子序列的方法

通過以上的思路和代碼,希望可以對大家有所啟迪和幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 美女露全身永久免费网站 | 欧美视| 99在线免费播放 | 婷婷福利| 国产一区二区三区免费在线视频 | 羞羞视频污 | 日韩性公交车上xxhd免费 | 18无删减羞羞网站动漫 | 99r在线观看| 香蕉91| 欧美日韩一区视频 | 日本成熟bbxxxxxxxx | 五月天婷婷网亚洲综合在线 | 99视频久久精品久久 | 女教师波多野结衣高清在线 | 日本不卡在线一区二区三区视频 | 嫩草影院永久在线一二三四 | 99爱免费 | 午夜DV内射一区区 | 99热在线免费观看 | 久久99精国产一区二区三区四区 | 国产视频一区二 | 久久九九有精品国产23百花影院 | 饭冈加奈子黑人解禁在线播放 | pron欧美| ipx-177绝对领域在线观看 | 国产亚洲玖玖玖在线观看 | 日韩小视频在线观看 | 校园高h| 国产愉拍精品视频手机 | 九九热这里只有精品视频免费 | 日本大乳护士的引诱图片 | 亚洲免费在线观看视频 | 精品湿| 精品亚洲午夜久久久久 | 香蕉人人超人人超碰超国产 | 羞羞答答影院在线 | hd在线观看免费高清视频 | 九九热视频免费观看 | 女教师波多野结衣高清在线 | 精品无码国产污污污免费网站2 |