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

一般企业做什么网站大庆建站公司

一般企业做什么网站,大庆建站公司,专业网站建设广州,武汉互联网企业排名第一题: 这个题是一个简单题,数据范围也特别小,所以直接使用模拟方式暴力解答。 直接进行行移动的过程,然后检查移动后的结果是否与移动前相同。 代码: ​ 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.mmbaike.com/news/44664.html

相关文章:

  • 哪个公司做网站最好自助建站网站
  • 秒收的网站百家号seo
  • 免注册个人网站制作建网站一般需要多少钱
  • 政府网站群建设总结西安百度快照优化
  • 网站建设和营销青岛seo推广专员
  • 湛蓝 网站开发长沙网站seo哪家公司好
  • 阜新市建设小学网站windows优化大师会员兑换码
  • 做网站去哪找源码站外推广免费网站
  • 如何做网站大图片宁波网站推广制作
  • 公司做网站好不好网站收录查询工具
  • 合肥市住房和城乡建设局网站深圳今天重大事件新闻
  • 中小企业建站电商平台引流推广
  • 邢台网站优化上海比较大的优化公司
  • 武汉吧哒科技怎么样长沙靠谱关键词优化服务
  • 国内网站设计案例欣赏上海seo关键词优化
  • 开发网站需要多久百度网讯科技客服人工电话
  • 网站建设推广优化招聘模板武汉java培训机构排名榜
  • 简述政府网站建设的重要性百度图片识别在线使用
  • 商丘网站建设和制作网站营销外包哪家专业
  • 国内网站开发不用wordpress怎样制作网页
  • 做网站需要注意多少页东莞优化排名公司
  • 网站建设网络推广营销推广渠道
  • 区块链 做网站百度关键词收费标准
  • 有什么网站可以做试题奇葩网站100个
  • 网站文章收录查询客户营销
  • 企业手机网站建设精英宁波外贸网站推广优化
  • 三合一网站介绍电脑培训机构
  • 国内可以做网页的网站关键词优化排名软件哪家好
  • 网站如何做跳转网络销售模式有哪些
  • 一个专门做字画的网站百度怎么打广告在首页