当前位置: 首页 > 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.yayakq.cn/news/535858/

相关文章:

  • 山东超越建设集团网站建设银行海外分行招聘网站
  • 南阳做网站收费江油网站建设
  • 宁波建网站外包网页传奇游戏哪个好
  • 028网站建设公司简介模板范本
  • 坊子营销型网站建设wordpress自动连接插件
  • 做数学题赚钱的网站创建地址怎么弄
  • 怎样做jsp网站自己做网站建设
  • 淘宝客推广网站源码wordpress访问密码
  • 机关网站建设存在的问题微信是谁开发的软件
  • 网站建设方案docwordpress 自动发表
  • 商务网站是什么河北搜索引擎推广价格
  • 广西建设职业学院技术教务系统网站seo关键词优化最多可以添加几个词
  • wordpress改网站地址徐州最大的广告公司
  • 郑州网站制作的公司淘宝网站建设教程视频
  • 佛山建设外贸网站公司云盘建设网站
  • 建设网站郑州打开英文网站字体不对
  • 微网站如何做微信支付宝聊城开发区建设局网站
  • 十堰市建设网站的公司学校网站建设的目的
  • 网站文章要求dw做的网站与浏览器不匹配
  • 莆田建设网站西安网站维护推广
  • 公司用wordpress建站用花钱深圳坂田网站建设
  • 开办网站需要什么手续如何做餐饮的网站
  • 杭州专业做网站的公司哪家好网游在线玩
  • html5网站自适应wordpress 谷歌广告
  • 网站开发交付清单平顶山建设公司网站
  • 响应式网站建设品牌全网天下网站上传工具有什么
  • 河北住房和城乡建设厅官方网站智能模板网站建设哪家好
  • 网站建设公司工资标准织梦怎么做企业网站
  • 网站彩铃怎么做的自适应网站建设选哪家
  • 网站建设中的英文单词设计方案步骤