自除数-C语言

描述

给定两个整数 leftright ,返回一个列表,列表的元素是范围 [left, right] 内所有的 自除数。

  • 1 <= left <= right <= 104

自除数 是指可以被它包含的每一位数整除的数,自除数 不允许包含 0 。例如,128 是一个 自除数 ,因为 128 % 1 == 0128 % 2 == 0128 % 8 == 0。

示例1

复制代码
输入:left = 1, right = 22
输出:[1, 2, 3, 4, 5, 6, 7, 8, 9, 11, 12, 15, 22]

示例2

复制代码
输入:left = 47, right = 85
输出:[48,55,66,77]

由于被判断的数不确定有是一个几位数,需用while判断,而判断自除数需要用取余运算判断每一位是否为0且这个数能否整除这个位数,。可以自定义一个函数,对边界中的每一个数进行判断是否为自除数,再自定义一个函数将自除数存放在数组中并返回

复制代码
#include<stdio.h>
#include<stdlib.h>
#include <stdbool.h>
#include "text.h"
//判断是否为自除数
bool isSelfDividing(int num)
{
    int a = num;
    while (a > 0)
    {
        int b = a % 10;
        if (b == 0 || num % b != 0)
        {
            return false;
        }
        a = a / 10;
    }
    return true;
}
//存边界内的自除数
int* selfDividingNumbers(int left, int right, int* returnSize) {
    //动态分配内存空间
    int* p = (int*)malloc(sizeof(int) * (right - left + 1));
    int pos = 0;
    for (int i = left; i <= right; i++)
    {
        if (isSelfDividing(i))
            p[pos++] = i;
    }
    *returnSize = pos;
    return p;
}int main()
{
    //输入边界
    int left, right;
    scanf("%d%d", &left, &right);
    //自除数个数
    int Size=0;
    //自除数数组
    int* p = selfDividingNumbers(left,right,&Size);
    for (int i = 0; i < Size; i++)
    {
        printf("%d\n", *(p + i));
    }
}
相关推荐
知乎的哥廷根数学学派17 分钟前
基于生成对抗U-Net混合架构的隧道衬砌缺陷地质雷达数据智能反演与成像方法(以模拟信号为例,Pytorch)
开发语言·人工智能·pytorch·python·深度学习·机器学习
yeziyfx1 小时前
kotlin中 ?:的用法
android·开发语言·kotlin
charlie1145141911 小时前
嵌入式的现代C++教程——constexpr与设计技巧
开发语言·c++·笔记·单片机·学习·算法·嵌入式
古城小栈1 小时前
Rust 网络请求库:reqwest
开发语言·网络·rust
hqwest2 小时前
码上通QT实战12--监控页面04-绘制6个灯珠及开关
开发语言·qt·qpainter·qt事件·stackedwidget
i橡皮擦2 小时前
TheIsle恐龙岛读取游戏基址做插件(C#语言)
开发语言·游戏·c#·恐龙岛·theisle
济6172 小时前
嵌入式C语言(第二期)
c语言
bing.shao2 小时前
golang 做AI任务执行
开发语言·人工智能·golang
源代码•宸3 小时前
Golang语法进阶(协程池、反射)
开发语言·经验分享·后端·算法·golang·反射·协程池
Dillon Dong4 小时前
STM32嵌入式:使用 MT29F8G08ABACAWP NAND 的FLASH全面指南
c语言·stm32