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

企业网站的网络营销专业做写生的网站

企业网站的网络营销,专业做写生的网站,企业网站建设合同书,wordpress 消息队列思路 方法一:使用Set集合 1.首先是三层for循环,遍历,并且遇到不满足的情况,便跳过,继续计算。不如前导为0,以及遍历同一个数组下标的情况 2.使用Set集合来确保答案是唯一的,使用桶来标记也是可以的 3.但是…

思路

方法一:使用Set集合

1.首先是三层for循环,遍历,并且遇到不满足的情况,便跳过,继续计算。不如前导为0,以及遍历同一个数组下标的情况 2.使用Set集合来确保答案是唯一的,使用桶来标记也是可以的 3.但是使用了Set集合就要将其转换为数组来返回,因为题目要求返回的是数组,并且也要用到一些Set的方法。
class Solution {public int[] findEvenNumbers(int[] digits) {Set<Integer> resultSet = new HashSet<>();int len = digits.length;for (int i = 0; i < len; i++) {if (digits[i] == 0) continue;for (int j = 0; j < len; j++) {if (j == i) continue;for (int k = 0; k < len; k++) {if (k == i || k == j || digits[k] % 2 != 0) continue;resultSet.add(digits[i] * 100 + digits[j] * 10 + digits[k]);}}}//将Set集合转为ListList<Integer> res = new ArrayList<>(resultSet);Collections.sort(res);int[] resultArray = new int[res.size()];for (int i = 0; i < res.size(); i++) {resultArray[i] = res.get(i);}return resultArray;}}

通过情况:

方法二:使用数字标记

1.因为是三位的偶数,所以只要大小为1k的数字即可

2.前面的判断条件都是一样的,不满足的情况就跳过

3.不同的是,因为不是Set集合,没有办法自动去重,但是好在范围只在100~999的偶数即可,所以i+=2

4.因为不知道有多少满足条件的数字,所以仍然使用List集合,并且在得到结果后再转为数组。

class Solution {public int[] findEvenNumbers(int[] digits) {int[] res=new int[1000];int len = digits.length;for (int i = 0; i < len; i++) {if (digits[i] == 0) continue;for (int j = 0; j < len; j++) {if (j == i) continue;for (int k = 0; k < len; k++) {if (k == i || k == j || digits[k] % 2 != 0||res[digits[i] * 100 + digits[j] * 10 + digits[k]]!=0) continue;res[digits[i] * 100 + digits[j] * 10 + digits[k]]++;}}}List<Integer> resultList=new ArrayList<>();for (int i = 100; i <999 ; i+=2) {if(res[i]!=0)resultList.add(i);}int[] resultArray = new int[resultList.size()];for (int i = 0; i < resultList.size(); i++) {resultArray[i] = resultList.get(i);}return resultArray;}}

通过情况:

方法三:直接对0~9出现的数字进行标记

1.既然方法二用的数组标记,是对100-999中的进行标记。那么还有没有更简便的方法呢?

2.直接对0-9的数字进行标记,出现了,则++

3.并且i从1开始,这样就可以避免前导0的问题,k+=2,就能确保找到的都是偶数

4.计算的时候暂时减去使用的次数,这是为了防止,后面的位数进行多次的使用,如果次数不足的情况下。计算完成后再加回来,因为便利和出现的次数无关,遍历是从0~9开始的遍历,如果数字不存在,则会跳过。

5.最后仍是将List转化为 int[ ],返回

class Solution {public int[] findEvenNumbers(int[] digits) {// 创建一个长度为10的数组cnt来记录digits中各个数字(0-9)出现的次数int[] cnt = new int[10];for (int d : digits) {cnt[d]++; // 统计每个数字出现的次数}// 创建一个列表list用于存储找到的所有符合条件的三位偶数List<Integer> list = new ArrayList<>();// 外层循环遍历可能的百位数字i (从1到9,避免前导零)for (int i = 1; i < 10; i++) {if (cnt[i] == 0) continue; // 如果该数字不存在于digits中,则跳过// 暂时减少百位数字i的计数,表示它已经被使用cnt[i]--;// 中间层循环遍历可能的十位数字j (从0到9)for (int j = 0; j < 10; j++) {if (cnt[j] == 0) continue; // 如果该数字不存在于digits中,则跳过// 暂时减少十位数字j的计数,表示它已经被使用cnt[j]--;// 内层循环遍历可能的个位数字k (从0到9,步长为2,确保是偶数)for (int k = 0; k < 10; k += 2) {if (cnt[k] > 0) { // 如果该偶数存在于digits中// 构建三位数并添加到结果列表中list.add(100 * i + 10 * j + k);}}// 恢复十位数字j的计数cnt[j]++;}// 恢复百位数字i的计数cnt[i]++;}// 将结果列表转换为数组int[] nums = new int[list.size()];for (int i = 0; i < list.size(); i++) {nums[i] = list.get(i);}// 返回结果数组return nums;}}

http://www.yayakq.cn/news/278966/

相关文章:

  • 学校网站建设栏目有哪些html网站地图在线生成
  • 河北建设厅网站首页郑州百姓网二手货车
  • 网上网站建设教程猎头公司一般怎么收费的
  • 做网站有什么市场风险dede安装好后是模板怎么变成做好的网站
  • 怎么做自己的外卖网站数码网站建设维护
  • 个人可以做微信小程序吗?20条优化措施
  • linux网站服务器搭建天元建设集团有限公司欠薪问题
  • 网站名称和域名不一致网站规划与建设书
  • 化工网站开发在线购物网站建设
  • 亦庄公司做网站公司名字大全20000个四个字
  • 网站搭建策略与方法有哪些方面企业网站硬件设计
  • 设计接单网站大全wordpress小工具放入用户中心
  • 江西网站设计电话做项目搭建网站 构建数据库
  • 大型网站维护费一年多少二级域名网站优化
  • 外贸网站建设的重要性宝塔反代wordpress
  • 深圳黑马品牌网站设计制作公司网站大概多少钱
  • 康定网站建设公司做淘宝必备网站
  • 餐饮门户网站源码网站开发大学
  • flash云网站产品网上推广的方法有哪些
  • 福建建设执业注册中心网站在线音乐网站 用什么做
  • 国家建设部官方网站投诉泉州自助建站
  • 快速的网站开发厦门seo网站管理
  • 一个服务器可以做多个网站吗会员视频网站建设
  • 专业网站设计联系dede程序数据库还原图文教程★适合dede网站迁移
  • 网站建设及推广套餐企业网站宣传视频外链
  • 怎么做军事小视频网站贵州水电建设局网站
  • 一个网站为什么做的不好看做管理信息的网站吗
  • 怎么用手机做网站平台辽阳微网站建设
  • 建设网站 课程设计百度推广一年大概多少钱
  • 南通海洲建设集团网站seo怎么提升关键词的排名