LogFactory.getLog(StringUtil.class); // 国标码和区位码转换常量 static final int GB_SP_DIFF = 160; //存放国标一级汉字不同读音的起始区位码...3106, 3212, 3472, 3635, 3722, 3730, 3858, 4027, 4086, 4390, 4558, 4684, 4925, 5249, 5600}; //存放国标一级汉字不同读音的起始区位码对应读音...'f', 'g', 'h', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'w', 'x', 'y', 'z'}; //获取一个字符串的拼音码...(temp); } else { buffer.append(convert(uniCode)); } } return buffer.toString(); } /** 获取一个汉字的拼音首字母...* GB码两个字节分别减去160,转换成10进制码组合就可以得到区位码 * 例如汉字“你”的GB码是0xC4/0xE3,分别减去0xA0(160)就是0x24/0x43 * 0x24转成10进制就是36
indexBar 项目开发中经常会使用到indexBar点击索引栏时,会自动跳转到对应的IndexAnchor锚点位置,完成快速检索功能 需要配合该组建使用的是把你的列表数据转换成对应的汉字的首字母完成该功能
使用Hutool工具类 官网链接 以下为Hutool支持的拼音库的pom坐标,你可以选择任意一个引入项目中,如果引入多个,Hutool会按照以上顺序选择第一个使用。...cn.hutool.extra.pinyin.PinyinUtil; public class Test { public static void main(String[] args) { // 获取全部汉字首字母...如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
,初始为函数参数in_string值 DECLARE tmp_len SMALLINT DEFAULT 0;#tmp_str的长度 DECLARE tmp_char VARCHAR(2) charset...VARCHAR(65534) charset gbk DEFAULT '';#结果字符串 DECLARE tmp_cc VARCHAR(2) charset gbk DEFAULT '';#拼音字符,存放单个汉字对应的拼音首字符...长度大于0则进入该while SET tmp_char = LEFT(tmp_str,1);#获取tmp_str最左端的首个字符,注意这里是获取首个字符,该字符可能是汉字,也可能不是。...SET tmp_cc = tmp_char;#左端首个字符赋值给拼音字符 IF LENGTH(tmp_char)>1 THEN#判断左端首个字符是多字节还是单字节字符,要是多字节则认为是汉字且作以下拼音获取...C','D','E','F','G','H','J','K','L','M','N','O','P','Q','R','S','T','W','X','Y','Z') INTO tmp_cc; #获得汉字拼音首字符
Function hztopy(hzpy As String) As String
java在处理项目需求时,有时需要排序,尤其是中文名字按0-9,A-Z进行首字母排序,这时候就需要首先要得到中文字符串的首字母,然后按照字母顺序进行排序,不多说,直接上代码,看java如何获取中文字符串首字母...: /** * 获取汉字串拼音首字母,英文字符不变 * @param chinese 汉字串 * @return 汉语拼音首字母 */ public...dW8blj104118"; String as = getFirstSpell("|||"); System.out.println(as); } 此时已经通过java得到了首字母...,剩下的就是去排序了。
create function [dbo].[fn_getpy] (@str nvarchar(4000)) returns nvarchar...
js链表的排序 链表数据交换的心得 假如通过两个地址进行交换节点内容时,也应当将我们的next来进行交换赋值, 或者可以不改动我们的...next,通过定义数据的中间量来将我们的数据进行改变 通过while循环找到我们想要交换的节点 sersort() { let p =...= null) { if (ppr.ser 的ser小于前一个的ser那么将我们的节点进行交换...如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
在项目中经常遇到需要验证输入内容的情况,可以通过 Javascript 判断输入内容,验证手机号或者是否为汉字。...简单的记录一下: HTML部分: 的姓名" value=""/> js 部分: 首先获取到元素: var uname = document.getElementById("name"); var umobile = document.getElementById("mobile...; } 验证输入的是否是汉字: var han = /^[\u4e00-\u9fa5]{2,9}$/; //设置汉字的正则表达式:2-9个汉字 if(!...han.test(uname.value)){ //验证输入的内容是否是2-9个汉字 alert("请输入汉字,不少于2个!")
一个功能需求,做一个类似联系人列表的功能,点击名称获取对应的id,样式简陋,只是一个模板,原来是uniapp项目,根据需要改成了vue,需要的自行设计css 流程 获取数据 提取首个字的拼音的首个字母...排序并分组 直接上代码吧 { { item.title}}...new Object(); obj.title = letters[i]; obj.datas = map[letters[i]].datas; turn.push(obj); } } //对景区名称进行排序...,复制下面的新建js文件 内部代码: /*!...如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
由于浏览器的原生支持(无需安装任何插件),用JS来学习数据结构和算法也许比c更加便捷些。因为只需一个浏览器就能啪啪啪的调试了。...比如下图我学习归并排序算法时,只看代码感觉怎么都理解不了,但是结合chrome自带的断点调试功能,我便很快理解了其中的思想。 ? 冒泡排序 排序是第一个可以被实际使用的排序算法。...归并排序JavaScript代码实现: 完整测试代码 快速排序 快速排序也许是最常用的排序算法了。它的复杂度为O(nlogn),且它的性能通常比其他的复 杂度为O(nlogn)的排序算法要好。...和归并排序一样,快速排序也使用分治的方法,将原始数组分 为较小的数组(但它没有像归并排序那样将它们分割开)。 chrome的sort()方法是基于快速排序实现的。 快速排序动图演示: ?
// 冒泡排序 var arr = [2, 4, 1, 6, 7, 8, 33, 11,77,88,99,3,100]; function sort(array...) { //使用双循环去遍历数组,第一个循环取 array 的一个数据,第二个循环拿上个循环数据的后面一个数据,两个数据进行比较。...if (array[i] > array[u]) { //如果 array[i] > 的数据...,然后把两个数据的下标进行更换,达到升序排序的效果。
大家好,又见面了,我是你们的朋友全栈君。 sort() 方法用于对数组的元素进行排序,并返回数组。默认排序顺序是根据字符串Unicode码点。...规定排序顺序。必须是函数。 注:如果调用该方法时没有使用参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。...如果想按照其他规则进行排序,就需要提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。...比较函数应该具有两个参数 a 和 b,其返回值如下: 若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值。 若 a 等于b,则返回 0。...简单点就是:比较函数两个参数a和b,返回a-b 升序,返回b-a 降序 //注:原数组发生改变 例: 1.不传参数,将不会按照数值大小排序,按照字符编码的顺序进行排序; var arr =
前天写计时小程序时候想要获得本月的所有天数遇到了梗! 正常的想法肯定头皮发麻! ?...那么还有什么可以简单获取到制定月份的天数吗?当然有呀! 接下来看一下骚操作!...let days=new Date(2018,7,0).getDate() 一行代码简单搞定获取制定月份的天数,什么原因呢! ?...,原来js中x年x月0号进行获取getDate()时候会返回本月最后一天是几号,这样我们就得到我们所需的数据了,最后一天几号就是多少题啦!...原文地址《js获取本月的天数》
在学习vue实现手机通讯录的功能之前,我们首先要了解如何将汉字转为拼音并获取其首字母,以下为汉字转拼音插件: 1. 新建 const.js 文件,定义常量。...代码太长就不贴了,需要的请参考下面原文链接的文章:vue集成汉字转拼音插件 2. 新建 vue-py.js 文件,实现汉字转拼音功能: import { pinyin } from '....) //获取汉字拼音首字母 let namePinyin = vPinyin.chineseToPinYin(salesmanName.substring(0, 1)); firstPinyin = namePinyin.substring...data(){ return { //根据通讯录名字得到的首字母 contacts:[], //处理过后的相应数据 listData: [], } }, 2....== '') { //获取汉字拼音首字母 let namePinyin = vPinyin.chineseToPinYin(salesmanName.substring
关于排序算法的问题可以在网上搜到一大堆,但是纯 JS 版比较零散,之前面试的时候特意整理了一遍,附带排序效率比较。...//1.冒泡排序 var bubbleSort = function(arr) { for (var i = 0, len = arr.length; i < len - 1; i++) {...] = arr[j]; arr[j] = temp; } } } return arr; }; //2.选择排序...left.length > 0 && right.length > 0) { if (left[0] < right[0]) { // shift()方法用于把数组的第一个元素从其中删除...,并返回第一个元素的值 result.push(left.shift()); } else { result.push(right.shift
在开发过程中,我们经常会遇到需要从一组产品名称或用户输入中提取每个单词的首字母,并生成一个简洁的缩写的场景。这种缩写通常用于展示产品、生成订单编号或是用于标签等场景中。...提取产品名称首字母生成产品代码 假设我们有一个电商平台,需要为每个产品生成一个简短的代码,这个代码由产品名称中每个单词的首字母组成。...使用正则表达式 /\b(\w)/g,我们可以匹配每个单词的首字母。 match 方法会返回一个包含匹配结果的数组,join('') 方法将这些字母连接成一个字符串,即产品代码。...正则表达式解释: \b:匹配单词的边界,也就是单词的开头或者空格后面的第一个字符。 \w:匹配字母或数字(在这个场景中,我们只关心字母)。 g:表示全局搜索,也就是匹配字符串中的所有符合条件的字符。...结束 通过使用JavaScript的正则表达式,我们可以轻松实现从字符串中提取每个单词首字母并生成缩写的功能。这种方法在实际业务场景中非常实用,特别是在需要简化文本展示或生成标识符的场合。
一个对象数组,按照不同的属性进行排序 /* * @Author: Tricia * @Date: 2023-01-30 14:51:19 * @Description: 获取最新时间的数据 */...2023-01-09T01:38:15.000Z', }, ] // 对象数组比较函数(默认升序) function compareVal(k, order = 'asc') { // k 属性的键...,order 排序方式 return function innerSort(a, b) { if (!...b.hasOwnProperty(k)) { // 该属性在任何对象上都不存在(即错误的属性) return 0 } // 判断要对比的属性的格式,字符串还是数字
一些排序算法 var Sort = {} Sort.prototype = { // 利用sort进行排序 systemSort:function(array){...key 是最小的数 if(tempi == i){ Sort(++i, tempj); return...45806244, 9651787, 2034035, 428481, 90358, 19001, 4025, 836, 182, 34, 9, 1] //针对大数组的步长选择...function tempSort(temp){ //console.log(temp) 使用的步长统计 var...for(j=1;/*j < tempLen && */temp * j + i < len; j++){ //依次循环每列的每行
} } if (thisTurnEndPos === endPos) { // 如果最后交换的位置不变则说明整体有序,排序完成 return arr }...O(n*n),最好的情况是O(n)、最差的情况是O(n*n) 空间复杂度是O(1) 特点:外层for循环控制循环次数、内层for循环进行两数交换,找出最大的数放到最后 改进: 1)处理在排序过程中数组整体已经有序的情况...,设置标志位 2)数组局部有序,遍历过程中记录最后一次交换的位置,设置为下一次交换的终点 3)同时将最大最小值归位,双向冒泡排序 2.实现一个快速排序算法 /** * 快速排序 * 1.选择一个基准...1)循环数组,每次取一个数,判断是否比已排序数最大的大 2)如果大则放在后面,如果小则继续比较,如果最小则放在最前面 /** * 插入排序1 */ function insertSort(arr)...每次循环选取一个最小的数字放到前面的有序序列中 function swap(arr, i, j) { var temp = arr[i] arr[i] = arr[j] arr[j] =
领取专属 10元无门槛券
手把手带您无忧上云