1.leetcode28. 实现 strStr()
实现 strStr() 函数。
给你两个字符串 haystack 和 needle ,请你在 haystack 字符串中找出 needle 字符串出现的第一个位置(下标从 0 开始)。如果不存在,则返回 -1 。
输入:haystack = "hello", needle = "ll"
输出:2
输入:haystack = "aaaaa", needle = "bba"
输出:-1
输入:haystack = "", needle = ""
输出:0
解题要点:
1.haystack&&needle为空字符串,返回0,或者仅有needle为空字符串,也返回0;
2.字符串截取substring(i,i+neddle.length())方法,看截取的字符串是否和neddle相等,需要注意i+neddle.length()要小于haystack.length();
3.java判断内容相等要用equals()方法,==只能判断引用地址相等
class Solution {
public int strStr(String haystack, String needle) {
int result = -1;
if (haystack.length() == 0 && needle.length() == 0) {
result = 0;
}
for (int i = 0; i + needle.length() <= haystack.length(); i++) {
if (haystack.substring(i, i + needle.length()).equals(needle)) {
result = i;
break;
}
}
return result;
}
}
使用 == 和 equals() 比较字符串。
equals() 方法用于将字符串与指定的对象比较。
String 类中重写了 equals() 方法用于比较两个字符串的内容是否相等。
使用 == 和 equals() 比较字符串。
String 中 == 比较引用地址是否相同,equals() 比较字符串的内容是否相同:
String s1 = "Hello"; // String 直接创建
String s2 = "Hello"; // String 直接创建
String s3 = s1; // 相同引用
String s4 = new String("Hello"); // String 对象创建
String s5 = new String("Hello"); // String 对象创建
s1 == s1; // true, 相同引用
s1 == s2; // true, s1 和 s2 都在公共池中,引用相同
s1 == s3; // true, s3 与 s1 引用相同
s1 == s4; // false, 不同引用地址
s4 == s5; // false, 堆中不同引用地址
s1.equals(s3); // true, 相同内容
s1.equals(s4); // true, 相同内容
s4.equals(s5); // true, 相同内容
2.遇到求子字符串,或者判断字符串相等问题可以考虑用substring()
3.sql
列出芝加哥以西的所有城市,从西到东排序
List all the cities west of Chicago, ordered from west to east
解答:SELECT city, longitude FROM north_american_cities WHERE longitude < -87.629798 ORDER BY longitude AS
从西向东,经度的度数由小到大为东经度;从西向东,经度的度数由大到小,为西经度
4.增删改查报错
整个流程:开启服务,监听http://127.0.0.1:,前端网页input框输入内容,通过v-model双向绑定将数据传给点击事件,点击事件拿到数据后赋值给变量,发送axios请求,后端通过get方法拿到axios请求url字符串携带的参数(req.query.参数),将参数传给下一个函数,连接数据库,拿到数据库里的结果,返回Promise函数,再把结果发送给前端(res.send()),前端拿到响应结果后赋值给数组,数组再通过v-for遍历,将查询结果渲染在页面上。
易出错点:
1.req.query.参数里的参数===url携带的参数===postman里的key;
2.url携带多个参数时用"&"连接,且要加=号("&addCode="+addCode);
3.get方法里的url字符串末尾不要加?号(app.get('/api/add', )),前端页面的要加("/api/add?addName=");
4.v-model里的数据要用this.获取
let server = app.listen(ServerCfgService.PORT4, function () {
var host = server.address().address
var port = server.address().port
console.log("url http://127.0.0.1:" + port + "/api/add");
})
<input type="text" v-model="id.addName" />
<input type="text" v-model="id.addCode" />
<input type="text" v-model="id.addDate" />
<input type="text" v-model="id.addPrice" />
<button @click="add">增加</button>
async add() {
let addName = this.id.addName;
let addCode = this.id.addCode;
let addDate = this.id.addDate;
let addPrice = this.id.addPrice;
let result = await HttpUtilBase.tryDoGet(
"/api/add?addName=" +
addName +
"&addCode=" +
addCode +
"&addDate=" +
addDate +
"&addPrice=" +
addPrice,
10000000,
3
);
app.get('/api/add', async function (req, res) {
let addMessage = await EastService.getInstance().addSQLData(req.query.addName, req.query.addCode, req.query.addDate, req.query.addPrice);
res.send(addMessage);
})