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

如何做产品销售网站国家市场监督管理总局官网

如何做产品销售网站,国家市场监督管理总局官网,公务员报名网站怎么做,四川省建设岗位注册中心网站【LetMeFly】1295.统计位数为偶数的数字:模拟 力扣题目链接:https://leetcode.cn/problems/find-numbers-with-even-number-of-digits/ 给你一个整数数组 nums,请你返回其中位数为 偶数 的数字的个数。 示例 1: 输入&#xff1…

【LetMeFly】1295.统计位数为偶数的数字:模拟

力扣题目链接:https://leetcode.cn/problems/find-numbers-with-even-number-of-digits/

给你一个整数数组 nums,请你返回其中位数为 偶数 的数字的个数。

 

示例 1:

输入:nums = [12,345,2,6,7896]
输出:2
解释:
12 是 2 位数字(位数为偶数) 
345 是 3 位数字(位数为奇数)  
2 是 1 位数字(位数为奇数) 
6 是 1 位数字 位数为奇数) 
7896 是 4 位数字(位数为偶数)  
因此只有 12 和 7896 是位数为偶数的数字

示例 2:

输入:nums = [555,901,482,1771]
输出:1 
解释: 
只有 1771 是位数为偶数的数字。

 

提示:

  • 1 <= nums.length <= 500
  • 1 <= nums[i] <= 105

解题方法一:正常模拟

如何判断一个(非负)数在十进制下有多少位?

当这个数不为0时拿这个数不断除以10,并将“数字位数”加一。

依次计算每个元素的位数,判断是否是偶数。

时空复杂度分析

  • 时间复杂度 O ( l e n ( n u m s ) × log ⁡ n u m s [ i ] ) O(len(nums)\times \log nums[i]) O(len(nums)×lognums[i])
  • 空间复杂度 O ( 1 ) O(1) O(1)

AC代码

C++
/** @Author: LetMeFly* @Date: 2025-04-30 17:23:40* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-04-30 17:25:14*/
#if defined(_WIN32) || defined(__APPLE__)
#include "_[1,2]toVector.h"
#endifclass Solution {
private:inline int getLength(int t) {int ans = 0;while (t) {ans++;t /= 10;}return ans;}
public:int findNumbers(vector<int>& nums) {int ans = 0;for (int t : nums) {ans += getLength(t) % 2 == 0;}return ans;}
};
Python
'''
Author: LetMeFly
Date: 2025-04-30 17:24:34
LastEditors: LetMeFly.xyz
LastEditTime: 2025-04-30 17:26:24
'''
from typing import Listclass Solution:def findNumbers(self, nums: List[int]) -> int:return sum(len(str(t)) % 2 == 0 for t in nums)
Java
/** @Author: LetMeFly* @Date: 2025-04-30 17:24:37* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-04-30 17:27:07*/
class Solution {private int getLength(int t) {int ans = 0;while (t > 0) {ans++;t /= 10;}return ans;}public int findNumbers(int[] nums) {int ans = 0;for (int t : nums) {if (getLength(t) % 2 == 0) {ans++;}}return ans;}
}
Go
/** @Author: LetMeFly* @Date: 2025-04-30 17:24:40* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-04-30 17:28:26*/
func findNumbers(nums []int) (ans int) {for _, t := range nums {cnt := 0for t > 0 {cnt++t /= 10}if cnt % 2 == 0 {ans++}}return
}

解题方法二:一次移除两位

方法一中我们将元素一次除以10(移除元素的一位),但是问题求的是“元素位数是否为偶数”,那么我们为什么不可以在元素位数大于等于2的时候,一次移除两位呢?最后看元素剩下一位还是零位不就知道元素十进制下的位数是奇数还是偶数了吗。

时空复杂度分析

  • 时间复杂度 O ( l e n ( n u m s ) × log ⁡ n u m s [ i ] ) O(len(nums)\times \log nums[i]) O(len(nums)×lognums[i])
  • 空间复杂度 O ( 1 ) O(1) O(1)
C++
/** @Author: LetMeFly* @Date: 2025-04-30 17:30:12* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-04-30 17:30:19*/
#if defined(_WIN32) || defined(__APPLE__)
#include "_[1,2]toVector.h"
#endifclass Solution {
public:int findNumbers(vector<int>& nums) {int ans = 0;for (int t : nums) {while (t >= 10) {t /= 100;}ans += t == 0;}return ans;}
};

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源

http://www.dtcms.com/wzjs/419163.html

相关文章:

  • 商城网站建设讯息今日资讯最新消息
  • 什么网站可以免费做兼职公司搜索seo
  • 淘宝网站框架seo教学网站
  • 百度官方网站怎么做网络营销有哪些推广平台
  • 网站加外链百度网站名称及网址
  • 网站流量监控做网站推广需要多少钱
  • 京东网站建设目标宽带营销策略
  • 简单网站建设的费用互联网推广是什么工作内容
  • 免费商业wordpress主题seo主要做什么
  • 门户网站规划如何去推广
  • 有没有专业做特产的网站东莞seo软件
  • pycharm 网站开发苏州百度推广分公司电话
  • 一个专门做字画的网站百度收录查询工具
  • 委托网站开发所有权归属商品营销推广的方法有哪些
  • 郑州做网站哪个营销软文
  • 网站开发 保密期限重庆百度推广
  • 怎样优化网站排名网奇seo赚钱培训
  • 东莞网站优化什么方法国内好的seo网站
  • 清远市专业网站制作网页设计制作网站素材
  • 中国外发加工网官网seo站长论坛
  • 怎么注册网站账号百度站长工具收费吗
  • 网站图片比例seo 优化是什么
  • 有哪些购物平台seo优化服务
  • 建设网站的行业现状分析迅雷磁力链bt磁力天堂
  • 内容网站设计范例seo关键词排名工具
  • 怎么做qq盗号网站google排名
  • 做高端网站公司百度旧版本下载
  • 在线做免费网站百度手机助手下载正版
  • 网站开发html2022年最火的电商平台
  • 公司哪家好点搜索引擎优化的方法有哪些