您好,欢迎访问一九零五行业门户网

Java数组、字符和等差数列问题怎么解决

题目一
 解法
class solution { public int[] relativesortarray(int[] arr1, int[] arr2) { int[] arr = new int[1001]; int[] ans = new int[arr1.length]; int index = 0; for(int i =0;i<arr1.length;i++){ arr[arr1[i]]+=1; } for(int i = 0;i<arr2.length;i++){ while(arr[arr2[i]]>0){ arr[arr2[i]]--; ans[index] = arr2[i]; index++; } } for(int i =0;i<arr.length;i++){ if(arr[i]!=0){ for(int j =0;j<arr[i];j++){ ans[index] = i; index++; } } } return ans; }}
题目二
解法
class solution { public int findlucky(int[] arr) { int[] nums = new int[500]; for(int i =0;i<arr.length;i++){ nums[arr[i]]+=1; } int max = -1; for(int i = 1;i<nums.length;i++){ if(i == nums[i]){ max = math.max(max,i); } } return max; }}
题目三
解法
class solution { public int maxpower(string s) { if(s.length()==1) return 1; int left = 1; int max = integer.min_value; int con = 1; while(left<s.length()){ if(s.charat(left)==s.charat(left-1)){ con++; max = math.max(con,max); }else{ max = math.max(con,max); con = 1; } left++; } return max; }}
题目四
解法
class solution { public boolean canmakearithmeticprogression(int[] arr) { arrays.sort(arr); int num = arr[1]-arr[0]; for(int i = 1;i<arr.length;i++){ if(arr[i]-arr[i-1]==num){ continue; }else{ return false; } } return true; }}
以上就是java数组、字符和等差数列问题怎么解决的详细内容。
其它类似信息

推荐信息