当前位置: 首页 > news >正文

廊坊宣传片制作公司重庆seo主管

廊坊宣传片制作公司,重庆seo主管,星彩医美连锁官方网站建设,aspx网站开发 案例第一题: 这个题是一个简单题,数据范围也特别小,所以直接使用模拟方式暴力解答。 直接进行行移动的过程,然后检查移动后的结果是否与移动前相同。 代码: ​ public class Solution {// 将指定行循环右移k次pri…
第一题:

这个题是一个简单题,数据范围也特别小,所以直接使用模拟方式暴力解答。

直接进行行移动的过程,然后检查移动后的结果是否与移动前相同。

代码:      

​
public class Solution {// 将指定行循环右移k次private int[] rotateRow(int[] row, int k) {int[] rotatedRow = new int[row.length];for (int i = 0; i < row.length; i++) {rotatedRow[(i + k) % row.length] = row[i];}return rotatedRow;}private int[][] rotateMatrix(int[][] matrix, int k) {int[][] rotatedMatrix = new int[matrix.length][matrix[0].length];for (int i = 0; i < rotatedMatrix.length; i++) {if (i % 2 == 0) {rotatedMatrix[i] = rotateRow(matrix[i], k % matrix[i].length);} else {rotatedMatrix[i] = rotateRow(matrix[i], matrix[i].length - (k % matrix[i].length));}}return rotatedMatrix;}// 检查两个矩阵是否完全相同private boolean isSameMatrix(int[][] matrix1, int[][] matrix2) {for (int i = 0; i < matrix1.length; i++) {for (int j = 0; j < matrix1[0].length; j++) {if (matrix1[i][j] != matrix2[i][j]) {return false;}}}return true;}// 判断初始矩阵和最终矩阵是否相同public boolean areSimilar(int[][] matrix, int k) {int[][] originalMatrix = new int[matrix.length][matrix[0].length];for (int i = 0; i < matrix.length; i++) {originalMatrix[i] = matrix[i].clone(); // 创建矩阵的副本}int[][] rotatedMatrix = rotateMatrix(matrix, k); // 循环移动k次return isSameMatrix(originalMatrix, rotatedMatrix);}
}​
第二题:

这个题目的思路也比较简单,主要就是两个方面进行考虑,一进行子字符串的截取,二判断子字符串是否是美丽字符串。子字符串的截取采用双指针进行解决,通过双指针的移动来不断截取子字符串然后,去判断当前截取的子字符串两种字符的数量是否满足规则。代码如下:

class Solution {public int beautifulSubstrings(String s, int k) {int count = 0;for (int i = 0; i < s.length(); i++) {int vowels = 0;int consonants = 0;for (int j = i; j < s.length(); j++) {char c = s.charAt(j);if (isVowel(c)) {vowels++;} else {consonants++;}if (vowels == consonants && (vowels * consonants) % k == 0) {count++;}}}return count;}private boolean isVowel(char c) {c = Character.toLowerCase(c);return c == 'a' || c == 'e' || c == 'i' || c == 'o' || c == 'u';}
}
第三题:

这个题目的思路是分组排序,把差距在limit的数字分为一组,每一组中的数据可以直接排序,然后把这个结果插入回原来的数组中,就得到结果。对于这个题目的解决思路就是先把所有元素进行排序然后记录原始的下标,然后通过limit来进行元素的分组。分好组后,针对每个分组的下标进行排序然后把最小的元素放在最小的下标。这样就得到了问题结果。

class Solution {public int[] lexicographicallySmallestArray(int[] nums, int limit) {int n = nums.length;// 将所有元素按照大小排序,并记录原始下标List<Pair<Integer, Integer>> list = new ArrayList<>();for (int i = 0; i < n; i++) {list.add(new Pair<>(nums[i], i));}list.sort((a, b) -> a.getKey() - b.getKey());// 将所有元素划分成若干子段,子段内相邻元素之差不超过 limitList<List<Pair<Integer, Integer>>> segments = new ArrayList<>();int last = -limit;for (int i = 0; i < n; i++) {if (list.get(i).getKey() - last > limit) {segments.add(new ArrayList<>());}segments.get(segments.size() - 1).add(list.get(i));last = list.get(i).getKey();}int[] ans = new int[n];// 对每个子段分别进行从小到大排序,并填回到序列中for (List<Pair<Integer, Integer>> segment : segments) {List<Integer> pos = new ArrayList<>();for (Pair<Integer, Integer> p : segment) {pos.add(p.getValue());}pos.sort(Comparator.naturalOrder());for (int i = 0; i < segment.size(); i++) {ans[pos.get(i)] = segment.get(i).getKey();}}return ans;}
}

http://www.qdjiajiao.com/news/9660.html

相关文章:

  • 如何利用路由建设网站互联网推广公司
  • 云南旅行社网站建设安卓优化大师hd
  • 浩森宇特北京网站建设北京百度网讯人工客服电话
  • 公司的网站费怎样做会计分录品牌网络推广怎么做
  • 网络营销推广及优化方案许昌seo推广
  • 网站主机ip查询seo建站优化推广
  • 北京网站建设的关键词网站推广是干嘛的
  • 有无专门做网站会员人数迅速增加的方法十大网站平台
  • 做国际黄金看什么网站免费注册网站
  • 安徽p2p网站建设惠州seo排名
  • 黄冈论坛网安阳seo
  • 网站备案要钱吗百度seo优化按年收费
  • 淄博网站建设优化国内时事新闻
  • 哪个网站可以做视频软件网络优化公司排名
  • 合伙企业怎么注册公司上海公司网站seo
  • 网站运营的工作内容搜索引擎优化搜索优化
  • 网站推广策略的控制和效果评价内江seo
  • 电子网站商业策划书推广网络营销案例
  • 做外单都有什么网站十句经典广告语
  • WordPress点击显示弹窗内容优化推广网站怎么做
  • 武汉做网站好的公司泰州seo网络公司
  • 物流企业网站友情链接交换网址大全
  • 商家入驻的商城平台百度的seo关键词优化怎么弄
  • 电子工厂网站建设百度关键词优化排名技巧
  • 中山做网站公司哪家好郑州疫情最新消息
  • 群晖ds218 做网站企业网络营销策略分析案例
  • 怎样建设一个购物网站今日头条站长平台
  • 网站建设参考文献广告投放公司
  • 连云港市网站建设网站优化外包公司
  • 夜夜做新郎网站lol关键词查询