- leetcode hot100-65 在排序数组中查找元素的第一个和最后一个位置
再不刷leetcode就找不到工作了
leetcode算法数据结构
方法一:利用≥,≤,>,<的性质,这也是因为题目中非递减顺序排列的整数数组classSolution{public:intlower_bound(vector&nums,inttarget){intleft=0;intright=nums.size()-1;while(left=target//所以left就是第一个>=target的元素下标returnleft;}vectorsearchRang
- C++ :顺序容器
愚戏师
c++rpc开发语言
一、顺序容器概述顺序容器通过元素在容器中的线性存储顺序来维护数据,允许通过位置(下标)访问元素。标准库提供6种核心顺序容器:容器类型头文件底层结构特点vector动态数组快速随机访问,尾部高效增删list双向链表任意位置高效插入/删除deque双端队列头尾高效增删,分段连续存储array(C++11)固定数组栈分配,尺寸不可变forward_list(C++11)单向链表最小内存开销,单向遍历st
- vector迭代器的使用以及迭代器失效
脑斧猴
数据结构
一、iterator的使用注意begin与end遵循左闭右开的原则,begin指向vector的第一个元素,end指向vector的最后一个元素的往下一个位置。rbegin与rendrbegin指向最后一个元素的位置,rend指向第一个元素的往前一个位置。二、vector的常用接口常用接口如下,不一一运行查看结果了,直接粘贴到本地运行看一下就懂了#include#include#includeus
- LeetCode 27:移除元素
风zx
LeetCodeleetcode
LeetCode27:移除元素解答:双指针解法一:快慢指针在最坏情况下(输入数组中没有元素等于val),左右指针各遍历了数组一次。但不会改变相对位置。classSolution{public:intremoveElement(vector&nums,intval){intn=nums.size();intleft=0;for(intright=0;right&nums,intval){intlef
- Leetcode 27:移除元素
Lance Jay
Leetcode刷题leetcode算法职场和发展
方法一:双指针,快指针遍历数组搜索保留值,慢指针指向下一个值的保存位置,最后返回慢指针索引即为最后数组长度。classSolution{public:intremoveElement(vector&nums,intval){intfast=0;intslow=0;//双指针,慢指针指向被替换的位置while(fast
- java实习生面试题_java实习生面试题(含答案)
11先生
java实习生面试题
1.Java容器框架有哪些?Java容器框架中有两个名称分别为Collection和Set的接口2.list,map,set,array,它们有什么区别(推荐学习:java实习生面试题)List接口主要有三个实现类:LinkedList,ArrayList,Vector.LinkedList:底层基于链表实现,链表内存是散乱的,每一个元素存储本身内存地址的同时还存储下一个元素的地址ArrayLis
- c++二分查找模板
wangyuxuan1029
c++算法模版c++开发语言
在C++中,二分查找(BinarySearch)是一种针对有序数组/容器的高效搜索算法,时间复杂度为O(logn)。其核心思想是通过不断缩小搜索范围,将目标值与中间元素比较,从而快速定位元素位置。以下是详细实现和注意事项:1.二分查找的前提条件数据必须是有序的(升序或降序)。适用于支持随机访问的容器(如数组、std::vector)。2.算法步骤初始化左右指针left=0,right=n-1(n为
- vector容器
乘秋川
C++基础语法c++
vector容器如何排序在C++中,可以使用std::sort函数对std::vector进行排序。std::sort是定义在头文件中的函数,可以对容器中的元素进行升序或降序排序。1.升序排序默认情况下,std::sort会对vector中的元素进行升序排序。#include#include#includeintmain(){std::vectorvec={5,2,9,1,5,6};//升序排序s
- QT核心模块QtCore功能详细说明,并给出测试代码(一)
旭唐
qt开发语言QTCore
目录一.核心数据类型(CoreDatatypes)1、QString2、QByteArray3、QVariant4、QList,QVector,QMap,QHash,QSetQList:有序列表,支持重复元素。QVector高效的动态数组QMap:基于红黑树的有序映射容器QHash:基于哈希表的无序映射容器QSet:集合类,存储不重复的元素应用场景及比较5、QDate,QTime,QDateTim
- 力扣55.跳跃游戏
进击的jerk
力扣leetcode游戏算法开发语言c++
55.跳跃游戏-力扣(LeetCode)代码区:classSolution{vectorjump(vectornums){intn=nums.size();vectorstep(n,1e6);//全部设置为1e6step[0]=0;for(inti=0;i&nums){intn=nums.size();vectorstep_ans(n);step_ans=jump(nums);if(step_an
- 【视频】OpenCV:色彩空间转换、灰度转伪彩
郭老二
视频opencv人工智能
1、颜色空间转换使用OpenCV的函数cv::applyColorMap可以将灰度或者正常的RGB格式图片,转换成其它伪彩色,代码很简单:1)使用cv::imread加载图片;2)使用std::vectormatrices暂存转换后的所有图像;3)使用cv::applyColorMap转换图片颜色;4)使用cv::vconcat拼接所有的图片;5)使用cv::imwrite保存图片;#includ
- 牛客周赛 Round 86 —— 题解
山海风z
算法小屋算法c++数据结构
A-小苯跑外卖_牛客周赛Round86签到题:向上取整#includeusingnamespacestd;intmain(){intx,y;cin>>x>>y;coutusingnamespacestd;#defineintlonglongsignedmain(){intt;cin>>t;while(t--){intn,k;cin>>n>>k;vectornums(n+1,0);intsum=0;
- 【C/C++】在排序数组中查找元素的第一个和最后一个位置(leetcode T34)
勇士小蓝0727
c语言c++leetcode开发语言算法数据结构蓝桥杯
核心考点:法一双指针法;法二二分查找法题目描述:给你一个按照非递减顺序排列的整数数组nums,和一个目标值target。请你找出给定目标值在数组中的开始位置和结束位置。如果数组中不存在目标值target,返回[-1,-1]。你必须设计并实现时间复杂度为O(logn)的算法解决此问题。(示例见文末)答案详解:方法一:双指针法vectorsearchRange(vector&nums,inttarge
- STM32:关于NVIC的工作与优先级分组方式
sewinger
stm32学习笔记单片机嵌入式硬件stm32
一,NVIC是什么NVIC,全称是NestedVectoredInterruptController,即嵌套向量中断控制器。它是ARMCortex-M系列处理器内核的一个重要组成部分,主要用于管理中断请求,协调中断的优先级,以及控制中断的嵌套执行,使得处理器能够高效、有序地响应和处理多个中断源。这个名称是如何体现的,下面一一说明。二,“嵌套”体现在哪?NVIC的嵌套体现在它能够处理多个中断的嵌套执
- Java高频面试之集合-07
牛马baby
java面试开发语言
hello啊,各位观众姥爷们!!!本baby今天来报道了!哈哈哈哈哈嗝面试官:ArrayList和Vector的区别是什么?ArrayList与Vector的区别详解ArrayList和Vector都是Java中基于动态数组实现的List接口的实现类,但它们在设计、性能和线程安全性上有显著差异。以下是两者的核心区别:1.线程安全性特性ArrayListVector线程安全非线程安全(方法未同步)线
- 求第k趟冒泡排序的结果
C嘎嘎嵌入式开发
算法算法数据结构排序算法
冒泡排序基本思想:重复地走访要排序的元素列,依次比较相邻的两个元素,如果顺序错误就交换它们,直到没有元素需要交换。时间复杂度:最坏和平均情况都是O(n²)。空间复杂度:O(1),属于原地排序。稳定性:稳定。求第k趟冒泡排序的结果voidsolve(){intn,k;cin>>n>>k;vectorv(n);for(inti=0;i>v[i];}if(k>n-1){//n个元素最多需要n-1趟排序s
- L2-050懂蛇语c++(pta天梯赛。测试点1。)
zzy678
c++
这个题目看上去还挺简单的,但是自己做的时候就超时了一开始只有19分。我自己stl学的不是很好,然后一开始自己用的pair和vector一起写的发现了一些小问题改了之后才得19。。。其中两个就是超时问题。可能查找太慢?之后又查看了一些别人写的,参考了使用map和vector混用的方法就很好过了,但是那个测试点1就是过不了。最后,我发现就是首字的处理方式应该优化。一个小小小坑。大家注意。#includ
- DAY33 贪心算法Ⅱ
Useee
贪心算法算法
122.买卖股票的最佳时机II-力扣(LeetCode)想到把整体利润分解为每天的利润,就豁然开朗了。classSolution{public:intmaxProfit(vector&prices){intresult=0;for(inti=1;i&nums){intcover=0;if(nums.size()==1)returntrue;for(inti=0;i=nums.size()-1)re
- dfs(二十五)22. 括号生成
曾几何时`
#DFSjavascript开发语言ecmascript
22.括号生成数字n代表生成括号的对数,请你设计一个函数,用于能够生成所有可能的并且有效的括号组合。示例1:输入:n=3输出:["((()))","(()())","(())()","()(())","()()()"]示例2:输入:n=1输出:["()"]提示:1res;vectorgenerateParenthesis(int_n){n=_n;dfs();returnres;}voiddfs()
- 如何使用多向量检索文档
scaFHIO
服务器linux运维python
在现代信息检索系统中,使用多个向量来检索单个文档是一个非常有用的技术。这种方法在多个应用场景中都有其优势,比如可以将文档分割为多个块,对这些块分别进行嵌入,从而提高语义检索的准确性。LangChain提供了一个baseMultiVectorRetriever类,为我们简化了这一过程。本文将详细讲解如何生成这些向量,并使用MultiVectorRetriever进行检索。1.技术背景介绍在信息检索中
- STM32八股【1】-----启动流程和startup文件理解
Invinciblenuonuo
stm32arm
启动流程知识点MCU上电复位。MSP从向量表第0个地址读取一个32位(2字节)的值并保存,该值为栈顶地址。PC计数器从第1个地址读取一个两字节的值并保存,该值为程序入口,一般是Reset_Handler。想了解FLASH地址映射可以看STM32八股【4】-----AHB地址映射__VectorsDCD__initial_sp;TopofStackDCDReset_Handler;ResetHand
- Effective Modern C++ 条款6:auto推导若非己愿,使用显式类型初始化惯用法
举个栗子2
EffectiveModernC++c++
更多C++学习笔记,关注wx公众号:cpp读书笔记Item6:Usetheexplicitlytypedinitializeridiomwhenautodeducesundesiredtypes在Item5中解释了比起显式指定类型使用auto声明变量有若干技术优势,但是有时当你想向左转auto却向右转。举个例子,假如我有一个函数,参数为Widget,返回一个std::vector,这里的bool表
- 贪心算法-455分发饼干
工大一只猿
贪心算法算法
classSolution{public:intfindContentChildren(vector&g,vector&s){sort(g.begin(),g.end());sort(s.begin(),s.end());intcount=0;inti=g.size()-1;intj=s.size()-1;for(i;i>=0;i--){if(j>=0&&s[j]>=g[i]){j--;count
- 动态数组索引越界问题
Caroline0071
C++基础知识动态数组索引越界vector
1、在C++中,可以采用几种不同的方法创建一个某种类型T的对象的数组。3种常用的方法如下:#defineN10//数组的长度N在编译时已知Tstatic_array[10];intn=20;//数组的长度n是在运行时计算的T*dynamic_array=newT[n];std::vectorvector_array;//数组的长度可以在运行时进行修改当然,我们仍然可以使用calloc()和mall
- java中vector和list_java中vector和list的区别
Creamy络
java中vector和list的区别发布时间:2020-06-1917:07:11来源:亿速云阅读:106作者:元一vector的概念Vector类是在java中可以实现自动增长的对象数组,vector在C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库。vector的使用连续存储结构:vector是可以实现动态增长的对象数组,支持对数组高效率的访问和在数
- 使用SQL-PGVector进行PostgreSQL与语义搜索/RAG的结合
fgayif
sqlpostgresql数据库python
在现代数据密集型应用中,语义搜索和检索增强生成(RAG)技术越来越受欢迎。通过结合PostgreSQL和pgvector扩展,我们可以实现高效的语义搜索。本文将深入探讨如何配置和使用SQL-PGVector,实现强大的数据查询能力。技术背景介绍PostgreSQL是一个功能强大的开源关系数据库,在处理结构化数据方面具备优势。为了增强其在非结构化数据处理中的能力,我们可以使用pgvector扩展,该
- 【C++】Vector和List的区别
信手斩龙
C++
在学习stl的时候,总是有同学分不清楚Vector和List的使用,在这里我总结一下它们的区别和使用方法。一、底层结构 vector的底层结构是动态顺序表,在内存中是一段连续的空间。 list的底层结构是带头节点的双向循环链表,在内存中不是一段连续的空间。二、支持随机访问 vector支持随机访问,可以利用下标精准定位到一个元素上,访问某个元素的时间复杂度是O(1)。 list不支持随机访问,要
- list和vector的区别
Ashen—one
listwindows数据结构
1>list可以按值删除vector和deque没有给定的函数,需要find();和erase();一起使用才能做到2>list删除元素会释放空间,vector不会3>list是双向迭代器,vector是随机迭代器4>list内部排序是指针指向的更改,vector涉及对象的创建和销毁5>vector改变元素,导致迭代器失效deque删除的时候不会导致迭代器失效(非迭代器位置),插入会导致迭代器失效
- 【C++】priority_queue的使用及模拟实现(含仿函数介绍)
梓䈑
C++学习c++开发语言
文章目录前言一、priority_queue的介绍二、priority_queue的使用三、仿函数四、priority_queue的模拟实现前言一、priority_queue的介绍(优先级队列是默认使用vector作为其底层存储数据的容器适配器,在vector上又使用了堆算法将vector中元素构造成堆的结构,因此priority_queue就是堆)二、priority_queue的使用及模拟实
- (LeetCode 热题 100) 74. 搜索二维矩阵(二分查找)
岁忧
java版刷题LeetCode热题100LeetCodeleetcode矩阵算法c++java
题目:74.搜索二维矩阵方法一:数组按行拼接为一个不下降的一维数组。采用二分查找,时间复杂度0(lognm)。C++版本:classSolution{public:boolsearchMatrix(vector>&matrix,inttarget){intn=matrix.size(),m=matrix[0].size();intl=0,r=n*m-1;while(ltarget){r=mid-1
- ztree设置禁用节点
3213213333332132
JavaScriptztreejsonsetDisabledNodeAjax
ztree设置禁用节点的时候注意,当使用ajax后台请求数据,必须要设置为同步获取数据,否者会获取不到节点对象,导致设置禁用没有效果。
$(function(){
showTree();
setDisabledNode();
});
- JVM patch by Taobao
bookjovi
javaHotSpot
在网上无意中看到淘宝提交的hotspot patch,共四个,有意思,记录一下。
7050685:jsdbproc64.sh has a typo in the package name
7058036:FieldsAllocationStyle=2 does not work in 32-bit VM
7060619:C1 should respect inline and
- 将session存储到数据库中
dcj3sjt126com
sqlPHPsession
CREATE TABLE sessions (
id CHAR(32) NOT NULL,
data TEXT,
last_accessed TIMESTAMP NOT NULL,
PRIMARY KEY (id)
);
<?php
/**
* Created by PhpStorm.
* User: michaeldu
* Date
- Vector
171815164
vector
public Vector<CartProduct> delCart(Vector<CartProduct> cart, String id) {
for (int i = 0; i < cart.size(); i++) {
if (cart.get(i).getId().equals(id)) {
cart.remove(i);
- 各连接池配置参数比较
g21121
连接池
排版真心费劲,大家凑合看下吧,见谅~
Druid
DBCP
C3P0
Proxool
数据库用户名称 Username Username User
数据库密码 Password Password Password
驱动名
- [简单]mybatis insert语句添加动态字段
53873039oycg
mybatis
mysql数据库,id自增,配置如下:
<insert id="saveTestTb" useGeneratedKeys="true" keyProperty="id"
parameterType=&
- struts2拦截器配置
云端月影
struts2拦截器
struts2拦截器interceptor的三种配置方法
方法1. 普通配置法
<struts>
<package name="struts2" extends="struts-default">
&
- IE中页面不居中,火狐谷歌等正常
aijuans
IE中页面不居中
问题是首页在火狐、谷歌、所有IE中正常显示,列表页的页面在火狐谷歌中正常,在IE6、7、8中都不中,觉得可能那个地方设置的让IE系列都不认识,仔细查看后发现,列表页中没写HTML模板部分没有添加DTD定义,就是<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3
- String,int,Integer,char 几个类型常见转换
antonyup_2006
htmlsql.net
如何将字串 String 转换成整数 int?
int i = Integer.valueOf(my_str).intValue();
int i=Integer.parseInt(str);
如何将字串 String 转换成Integer ?
Integer integer=Integer.valueOf(str);
如何将整数 int 转换成字串 String ?
1.
- PL/SQL的游标类型
百合不是茶
显示游标(静态游标)隐式游标游标的更新和删除%rowtyperef游标(动态游标)
游标是oracle中的一个结果集,用于存放查询的结果;
PL/SQL中游标的声明;
1,声明游标
2,打开游标(默认是关闭的);
3,提取数据
4,关闭游标
注意的要点:游标必须声明在declare中,使用open打开游标,fetch取游标中的数据,close关闭游标
隐式游标:主要是对DML数据的操作隐
- JUnit4中@AfterClass @BeforeClass @after @before的区别对比
bijian1013
JUnit4单元测试
一.基础知识
JUnit4使用Java5中的注解(annotation),以下是JUnit4常用的几个annotation: @Before:初始化方法 对于每一个测试方法都要执行一次(注意与BeforeClass区别,后者是对于所有方法执行一次)@After:释放资源 对于每一个测试方法都要执行一次(注意与AfterClass区别,后者是对于所有方法执行一次
- 精通Oracle10编程SQL(12)开发包
bijian1013
oracle数据库plsql
/*
*开发包
*包用于逻辑组合相关的PL/SQL类型(例如TABLE类型和RECORD类型)、PL/SQL项(例如游标和游标变量)和PL/SQL子程序(例如过程和函数)
*/
--包用于逻辑组合相关的PL/SQL类型、项和子程序,它由包规范和包体两部分组成
--建立包规范:包规范实际是包与应用程序之间的接口,它用于定义包的公用组件,包括常量、变量、游标、过程和函数等
--在包规
- 【EhCache二】ehcache.xml配置详解
bit1129
ehcache.xml
在ehcache官网上找了多次,终于找到ehcache.xml配置元素和属性的含义说明文档了,这个文档包含在ehcache.xml的注释中!
ehcache.xml : http://ehcache.org/ehcache.xml
ehcache.xsd : http://ehcache.org/ehcache.xsd
ehcache配置文件的根元素是ehcahe
ehcac
- java.lang.ClassNotFoundException: org.springframework.web.context.ContextLoaderL
白糖_
javaeclipsespringtomcatWeb
今天学习spring+cxf的时候遇到一个问题:在web.xml中配置了spring的上下文监听器:
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
随后启动
- angular.element
boyitech
AngularJSAngularJS APIangular.element
angular.element
描述: 包裹着一部分DOM element或者是HTML字符串,把它作为一个jQuery元素来处理。(类似于jQuery的选择器啦) 如果jQuery被引入了,则angular.element就可以看作是jQuery选择器,选择的对象可以使用jQuery的函数;如果jQuery不可用,angular.e
- java-给定两个已排序序列,找出共同的元素。
bylijinnan
java
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
public class CommonItemInTwoSortedArray {
/**
* 题目:给定两个已排序序列,找出共同的元素。
* 1.定义两个指针分别指向序列的开始。
* 如果指向的两个元素
- sftp 异常,有遇到的吗?求解
Chen.H
javajcraftauthjschjschexception
com.jcraft.jsch.JSchException: Auth cancel
at com.jcraft.jsch.Session.connect(Session.java:460)
at com.jcraft.jsch.Session.connect(Session.java:154)
at cn.vivame.util.ftp.SftpServerAccess.connec
- [生物智能与人工智能]神经元中的电化学结构代表什么?
comsci
人工智能
我这里做一个大胆的猜想,生物神经网络中的神经元中包含着一些化学和类似电路的结构,这些结构通常用来扮演类似我们在拓扑分析系统中的节点嵌入方程一样,使得我们的神经网络产生智能判断的能力,而这些嵌入到节点中的方程同时也扮演着"经验"的角色....
我们可以尝试一下...在某些神经
- 通过LAC和CID获取经纬度信息
dai_lm
laccid
方法1:
用浏览器打开http://www.minigps.net/cellsearch.html,然后输入lac和cid信息(mcc和mnc可以填0),如果数据正确就可以获得相应的经纬度
方法2:
发送HTTP请求到http://www.open-electronics.org/celltrack/cell.php?hex=0&lac=<lac>&cid=&
- JAVA的困难分析
datamachine
java
前段时间转了一篇SQL的文章(http://datamachine.iteye.com/blog/1971896),文章不复杂,但思想深刻,就顺便思考了一下java的不足,当砖头丢出来,希望引点和田玉。
-----------------------------------------------------------------------------------------
- 小学5年级英语单词背诵第二课
dcj3sjt126com
englishword
money 钱
paper 纸
speak 讲,说
tell 告诉
remember 记得,想起
knock 敲,击,打
question 问题
number 数字,号码
learn 学会,学习
street 街道
carry 搬运,携带
send 发送,邮寄,发射
must 必须
light 灯,光线,轻的
front
- linux下面没有tree命令
dcj3sjt126com
linux
centos p安装
yum -y install tree
mac os安装
brew install tree
首先来看tree的用法
tree 中文解释:tree
功能说明:以树状图列出目录的内容。
语 法:tree [-aACdDfFgilnNpqstux][-I <范本样式>][-P <范本样式
- Map迭代方式,Map迭代,Map循环
蕃薯耀
Map循环Map迭代Map迭代方式
Map迭代方式,Map迭代,Map循环
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
蕃薯耀 2015年
- Spring Cache注解+Redis
hanqunfeng
spring
Spring3.1 Cache注解
依赖jar包:
<!-- redis -->
<dependency>
<groupId>org.springframework.data</groupId>
<artifactId>spring-data-redis</artifactId>
- Guava中针对集合的 filter和过滤功能
jackyrong
filter
在guava库中,自带了过滤器(filter)的功能,可以用来对collection 进行过滤,先看例子:
@Test
public void whenFilterWithIterables_thenFiltered() {
List<String> names = Lists.newArrayList("John"
- 学习编程那点事
lampcy
编程androidPHPhtml5
一年前的夏天,我还在纠结要不要改行,要不要去学php?能学到真本事吗?改行能成功吗?太多的问题,我终于不顾一切,下定决心,辞去了工作,来到传说中的帝都。老师给的乘车方式还算有效,很顺利的就到了学校,赶巧了,正好学校搬到了新校区。先安顿了下来,过了个轻松的周末,第一次到帝都,逛逛吧!
接下来的周一,是我噩梦的开始,学习内容对我这个零基础的人来说,除了勉强完成老师布置的作业外,我已经没有时间和精力去
- 架构师之流处理---------bytebuffer的mark,limit和flip
nannan408
ByteBuffer
1.前言。
如题,limit其实就是可以读取的字节长度的意思,flip是清空的意思,mark是标记的意思 。
2.例子.
例子代码:
String str = "helloWorld";
ByteBuffer buff = ByteBuffer.wrap(str.getBytes());
Sy
- org.apache.el.parser.ParseException: Encountered " ":" ": "" at line 1, column 1
Everyday都不同
$转义el表达式
最近在做Highcharts的过程中,在写js时,出现了以下异常:
严重: Servlet.service() for servlet jsp threw exception
org.apache.el.parser.ParseException: Encountered " ":" ": "" at line 1,
- 用Java实现发送邮件到163
tntxia
java实现
/*
在java版经常看到有人问如何用javamail发送邮件?如何接收邮件?如何访问多个文件夹等。问题零散,而历史的回复早已经淹没在问题的海洋之中。
本人之前所做过一个java项目,其中包含有WebMail功能,当初为用java实现而对javamail摸索了一段时间,总算有点收获。看到论坛中的经常有此方面的问题,因此把我的一些经验帖出来,希望对大家有些帮助。
此篇仅介绍用
- 探索实体类存在的真正意义
java小叶檀
POJO
一. 实体类简述
实体类其实就是俗称的POJO,这种类一般不实现特殊框架下的接口,在程序中仅作为数据容器用来持久化存储数据用的
POJO(Plain Old Java Objects)简单的Java对象
它的一般格式就是
public class A{
private String id;
public Str