C语言编写 输出[m,n]范围内所有“韩信点兵“数。

Description

输出[m,n]范围内所有"韩信点兵"数。

所谓韩信点兵数就是指"除以3余2,除以5余3,除以7余4"的整数。

Input

2个正整数m和n,

1≤m≤n≤100000。

Output

首先在一行中输出所有的韩信点兵数。如果一个都没有,该行就不存在了。

第二行输出第一行输出的整数个数。

整数之间用1个空格隔开,行首行末均无空格。

输入样例 1

1 1000

输出样例 1

53 158 263 368 473 578 683 788 893 998

total=10

cpp 复制代码
 
#include <stdio.h>
#include <stdbool.h>
 bool isHanXin(int num) {
    return (num % 3 == 2 && num % 5 == 3 && num % 7 == 4);
}
 int main() {
    int m, n;
    scanf("%d %d", &m, &n);
     int count = 0;
    bool isFirst = true;
     for (int i = m; i <= n; i++) {
        if (isHanXin(i)) {
            if (!isFirst) {
                printf(" ");
            }
            printf("%d", i);
            count++;
            isFirst = false;
        }
    }
     printf("\ntotal=%d\n", count);
    return 0;
}

这段代码实现了输入两个正整数m和n,然后判断[m,n]范围内的所有"韩信点兵"数,并进行中文输出。其中,isHanXin函数用于判断一个数是否满足"韩信点兵"的条件。在输出韩信点兵数时,我们使用一个布尔变量isFirst来判断当前的数字是否为第一个韩信点兵数,如果不是第一个数,则在输出前先打印一个空格。这样就避免了最后一个数字后面的多余空格。最后,输出韩信点兵数的总个数。

相关推荐
robch1 天前
golang container/heap 是一个为任意类型实现堆(优先队列)接口的包
数据结构·算法·golang
96771 天前
力扣面试经典150 88. 合并两个有序数组 归并排序的merge函数
算法·leetcode·面试
放下华子我只抽RuiKe51 天前
算法的试金石:模型训练、评估与调优的艺术
人工智能·深度学习·算法·机器学习·自然语言处理·数据挖掘·线性回归
oem1101 天前
C++中的享元模式实战
开发语言·c++·算法
流云鹤1 天前
每日一题0316
算法
leonkay1 天前
Golang语言闭包完全指南
开发语言·数据结构·后端·算法·架构·golang
雅欣鱼子酱1 天前
Type-C供电PD协议取电Sink芯片ECP5702,可二端头分开供电调整亮度,适用于LED灯带户外防水超亮灯条方案
c语言·开发语言
颜酱1 天前
BFS 与并查集实战总结:从基础框架到刷题落地
javascript·后端·算法
casual~1 天前
第?个质数(埃氏筛算法)
数据结构·c++·算法
仰泳的熊猫1 天前
题目2308:蓝桥杯2019年第十届省赛真题-旋转
数据结构·c++·算法·蓝桥杯