目录
392. 判断子序列
力扣给定字符串 s 和 t ,判断 s 是否为 t 的子序列。
字符串的一个子序列是原始字符串删除一些(也可以不删除)字符而不改变剩余字符相对位置形成的新字符串。(例如,"ace"是"abcde"的一个子序列,而"aec"不是)。
示例 1:
输入:s = "abc", t = "ahbgdc"
输出:true
示例 2:输入:s = "axc", t = "ahbgdc"
输出:false
此题可以使用双指针,顾名思义,就是两个变量i和j,假如i指向s字符串,j指向t字符串。
两个变量都以一定的方式移动,将两个字符串放到一个循环中遍历,i为慢指针,j为快指针。
只有s.charAt(i)==t.charAt(j)是指针i才移动,但是j每次遍历都会移动,当字符串的长度等于i的时候就代表s是t的子串。
代码如下
class Solution {
public boolean isSubsequence(String s, String t) {
int i=0,j=0;
while (j<t.length()&&i<s.length()){
if (s.charAt(i)==t.charAt(j)){
i++;
}
j++;
}
return i==s.length();
}
}
455. 分发饼干
假设你是一位很棒的家长,想要给你的孩子们一些小饼干。但是,每个孩子最多只能给一块饼干。
对每个孩子 i,都有一个胃口值 g[i],这是能让孩子们满足胃口的饼干的最小尺寸;并且每块饼干 j,都有一个尺寸 s[j] 。如果 s[j] >= g[i],我们可以将这个饼干 j 分配给孩子 i ,这个孩子会得到满足。你的目标是尽可能满足越多数量的孩子,并输出这个最大数值。
示例 1:输入: g = [1,2,3], s = [1,1]
输出: 1
解释:
你有三个孩子和两块小饼干,3个孩子的胃口值分别是:1,2,3。
虽然你有两块小饼干,由于他们的尺寸都是1,你只能让胃口值是1的孩子满足。
所以你应该输出1。
示例 2:输入: g = [1,2], s = [1,2,3]
输出: 2
解释:
你有两个孩子和三块小饼干,2个孩子的胃口值分别是1,2。
你拥有的饼干数量和尺寸都足以让所有孩子满足。
所以你应该输出2.
这是一道贪心思想非常明显的题目,为了让更多的孩子满足,肯定是按需分配,小饼干喂胃口小的,大饼干喂肚子大的。
为了实现这种分配方式,首先对两个数组进行排序,为了就是让小的数在前面,胃口小的孩子,可以得到比小孩子胃口相对大或者等于的饼干,贪心算法的思想就是让局部最优,其结果大部分条件下也是最优的,然后用双指针在两个数组遍历比较元素,根据大小情况移动指针。
import java.util.Arrays;
class Solution {
//贪心的思想是,用尽量小的饼干去满足小需求的孩子,所以需要进行排序先
public int findContentChildren(int[] g, int[] s) {
int child = 0;
int cookie = 0;
Arrays.sort(g); //先将饼干 和 孩子所需大小都进行排序
Arrays.sort(s);
while (child < g.length && cookie < s.length ){ //当其中一个遍历就结束
if (g[child] <= s[cookie]){ //当用当前饼干可以满足当前孩子的需求,可以满足的孩子数量+1
child++;
}
cookie++; // 饼干只可以用一次,因为饼干如果小的话,就是无法满足被抛弃,满足的话就是被用了
}
return child;
}
}