(58)统计能整除数字的位数(59)重新排列数组

2024-03-17 20:04

本文主要是介绍(58)统计能整除数字的位数(59)重新排列数组,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 1. 每日一言
  • 2. 题目 (58)统计能整除数字的位数
  • 3. 解题思路
  • 4. 代码
  • 5. 题目 (59)重新排列数组
  • 6.解题思路
  • 7. 代码
  • 8. 结语


1. 每日一言

小舟从此逝,江海寄余生。 -苏轼-


2. 题目 (58)统计能整除数字的位数

题目链接:统计能整除数字的位数

给你一个整数 num ,返回 num 中能整除 num 的数位的数目。

如果满足 nums % val == 0 ,则认为整数 val 可以整除 nums 。

  • 示例 1:
    输入:num = 7
    输出:1
    解释:7 被自己整除,因此答案是 1 。

  • 示例 2:
    输入:num = 121
    输出:2
    解释:121 可以被 1 整除,但无法被 2 整除。由于 1 出现两次,所以返回 2 。

  • 示例 3:
    输入:num = 1248
    输出:4
    解释:1248 可以被它每一位上的数字整除,因此答案是 4 。

提示:
1 <= num <= 109
num 的数位中不含 0


3. 解题思路

  1. 声明一个变量tmp,用于存储原始的输入数值num。
  2. 声明一个变量sum,用于累计能整除num本身的数字个数。
  3. 使用while循环,条件为tmp的值不等于0。
  4. 在循环中,通过求余操作(tmp % 10)来获取num的最后一位数字,并将其与num本身进行取模操作(num % (tmp % 10))。
  5. 如果取模结果等于0,说明该数字可以整除num本身,将sum自增1。
  6. 将tmp除以10,舍去最后一位数字,以处理下一位数字。
  7. 循环执行以上步骤,直到将num的所有位数处理完毕。
  8. 返回sum作为函数的输出结果。

4. 代码

int countDigits(int num) {int tmp = num;//拷贝一份numint sum = 0;while(tmp) {//将tmp的每一位取下来,算一下能否整除numif(num%(tmp%10)==0) {++sum;}tmp/=10;}return sum;
}

5. 题目 (59)重新排列数组

题目链接:重新排列数组

给你一个数组 nums ,数组中有 2n 个元素,按 [x1,x2,…,xn,y1,y2,…,yn] 的格式排列。

请你将数组按 [x1,y1,x2,y2,…,xn,yn] 格式重新排列,返回重排后的数组。

  • 示例 1:
    输入:nums = [2,5,1,3,4,7], n = 3
    输出:[2,3,5,4,1,7]
    解释:由于 x1=2, x2=5, x3=1, y1=3, y2=4, y3=7 ,所以答案为 [2,3,5,4,1,7]

  • 示例 2:
    输入:nums = [1,2,3,4,4,3,2,1], n = 4
    输出:[1,4,2,3,3,2,4,1]

  • 示例 3:
    输入:nums = [1,1,2,2], n = 2
    输出:[1,2,1,2]

提示:
1 <= n <= 500
nums.length == 2n
1 <= nums[i] <= 10^3

6.解题思路

  1. 使用malloc函数为洗牌结果数组arr分配内存空间,大小为2n。
  2. 声明两个指针p1和p2,分别指向数组nums的前半部分和后半部分。
  3. 声明两个计数器j和k,分别用于遍历指针p1和p2所指向的元素。
  4. 使用for循环遍历数组nums的所有元素。
  5. 对于奇数索引(i的值为偶数),将指针p1所指向的元素赋值给洗牌结果数组arr的当前位置,并将计数器j自增1。
  6. 对于偶数索引(i的值为奇数),将指针p2所指向的元素赋值给洗牌结果数组arr的当前位置,并将计数器k自增1。
  7. 循环执行以上步骤,直到遍历完所有元素。

7. 代码

/*** Note: The returned array must be malloced, assume caller calls free().*/
int* shuffle(int* nums, int numsSize, int n, int* returnSize){int* arr = (int*)malloc(sizeof(int)*2*n);int *p1 = nums;int *p2 = nums+n;int j = 0,k=0;for(int i = 0;i<numsSize;i++) {if(0 == i%2){arr[i] = p1[j];j++;}else{arr[i] = p2[k]; k++;}}*returnSize = numsSize;return arr;
}

8. 结语

请给自己些耐心,一口吃不成胖子。
山外青山楼外楼,莫把百尺当尽头。
保持空杯心态加油努力吧!


都看到这里啦!真棒(*^▽^*)

可以给作者一个免费的赞赞吗,这将会鼓励我继续创作,谢谢大家

编程小白写作,如有纰漏或错误,欢迎指正


这篇关于(58)统计能整除数字的位数(59)重新排列数组的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/820004

相关文章

使用PyTorch实现手写数字识别功能

《使用PyTorch实现手写数字识别功能》在人工智能的世界里,计算机视觉是最具魅力的领域之一,通过PyTorch这一强大的深度学习框架,我们将在经典的MNIST数据集上,见证一个神经网络从零开始学会识... 目录当计算机学会“看”数字搭建开发环境MNIST数据集解析1. 认识手写数字数据库2. 数据预处理的

java字符串数字补齐位数详解

《java字符串数字补齐位数详解》:本文主要介绍java字符串数字补齐位数,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java字符串数字补齐位数一、使用String.format()方法二、Apache Commons Lang库方法三、Java 11+的St

C++原地删除有序数组重复项的N种方法

《C++原地删除有序数组重复项的N种方法》给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度,不要使用额外的数组空间,你必须在原地修改输入数组并在使用O(... 目录一、问题二、问题分析三、算法实现四、问题变体:最多保留两次五、分析和代码实现5.1、问题分析5.

一文详解SQL Server如何跟踪自动统计信息更新

《一文详解SQLServer如何跟踪自动统计信息更新》SQLServer数据库中,我们都清楚统计信息对于优化器来说非常重要,所以本文就来和大家简单聊一聊SQLServer如何跟踪自动统计信息更新吧... SQL Server数据库中,我们都清楚统计信息对于优化器来说非常重要。一般情况下,我们会开启"自动更新

python中的整除向下取整的操作方法

《python中的整除向下取整的操作方法》Python中的//是整数除法运算符,用于执行向下取整的除法,返回商的整数部分,不会四舍五入,它在分治法、索引计算和整数运算中非常有用,本文给大家介绍pyth... 目录1. // 的基本用法2. // vs /(普通除法)3. // 在 mid = len(lis

Java中数组转换为列表的两种实现方式(超简单)

《Java中数组转换为列表的两种实现方式(超简单)》本文介绍了在Java中将数组转换为列表的两种常见方法使用Arrays.asList和Java8的StreamAPI,Arrays.asList方法简... 目录1. 使用Java Collections框架(Arrays.asList)1.1 示例代码1.

C++一个数组赋值给另一个数组方式

《C++一个数组赋值给另一个数组方式》文章介绍了三种在C++中将一个数组赋值给另一个数组的方法:使用循环逐个元素赋值、使用标准库函数std::copy或std::memcpy以及使用标准库容器,每种方... 目录C++一个数组赋值给另一个数组循环遍历赋值使用标准库中的函数 std::copy 或 std::

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

C++ Primer 多维数组的使用

《C++Primer多维数组的使用》本文主要介绍了多维数组在C++语言中的定义、初始化、下标引用以及使用范围for语句处理多维数组的方法,具有一定的参考价值,感兴趣的可以了解一下... 目录多维数组多维数组的初始化多维数组的下标引用使用范围for语句处理多维数组指针和多维数组多维数组严格来说,C++语言没

Java数字转换工具类NumberUtil的使用

《Java数字转换工具类NumberUtil的使用》NumberUtil是一个功能强大的Java工具类,用于处理数字的各种操作,包括数值运算、格式化、随机数生成和数值判断,下面就来介绍一下Number... 目录一、NumberUtil类概述二、主要功能介绍1. 数值运算2. 格式化3. 数值判断4. 随机