C语言_练习题

求最小公倍数

思路:假设两个数,5和7,那么最小至少也要7吧,所以先假定最小公倍数是两个数之间较大的,然后看7能不能同时整除5和7,不能就加1继续除

cpp 复制代码
int GetLCM(int _num1, int _num2)
{
	int max = _num1>_num2 ? _num1 : _num2;
	while (1)
	{
		//证明能同时整除
		if (!(max%_num1) && !(max%_num2)) return max;
		else max++;
	}
}

int main()
{
	//输入两个正整数
	int num1, num2;
	scanf("%d %d", &num1, &num2);
	printf("%d\n", GetLCM(num1, num2));
	return 0;
}

上面的方法效率太低需要优化

思路:a*i % b 看看能不能整除,能就a*i是最小公倍数,不能就i++

cpp 复制代码
int main()
{
	//输入两个数
	int a, b;
	scanf("%d %d", &a, &b);
	//判断
	int i = 1;
	while (a*i % b) i++;
	printf("%d\n", a*i);
	return 0;
}

倒置字符串

思路:1. scanf这个函数它读到空格它就不读了,所以我们要这样写scanf("%[^\n]s"),它的意思是往后读一直读到\n。

  1. 先把整个字符串倒置,再将每个单词倒置
cpp 复制代码
void reverse(char* start, char* end)
{
    char tmp;
    while (start < end)
    {
        tmp = *start;
        *start = *end;
        *end = tmp;
        start++;
        end--;
    }
}

int main() {
    char arr[100];
    scanf("%[^\n]s", arr);

    int len = strlen(arr);
    char* start = arr;
    char* end = start + (len - 1);
    reverse(start, end); //倒置整个数组

    start = arr;
    end = arr;
    while (*end++)
    {
        
        while (*end != ' ' && *end != '\0')
        {
            end++;
        }
        reverse(start, end - 1);
        start = end + 1;
    }

    printf("%s\n", arr);
    return 0;
}











解析:3和2都是整数,所以3/2等于1






相关推荐
仟濹5 分钟前
算法打卡day2 (2026-02-07 周五) | 算法: DFS | 3_卡码网99_计数孤岛_DFS
算法·深度优先
驭渊的小故事8 分钟前
简单模板笔记
数据结构·笔记·算法
YuTaoShao24 分钟前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法一)前后缀分解
算法·leetcode·职场和发展
暮色妖娆丶27 分钟前
SpringBoot 启动流程源码分析 ~ 它其实不复杂
spring boot·后端·spring
BD_Marathon28 分钟前
设计模式——依赖倒转原则
java·开发语言·设计模式
VT.馒头30 分钟前
【力扣】2727. 判断对象是否为空
javascript·数据结构·算法·leetcode·职场和发展
Coder_Boy_35 分钟前
Deeplearning4j+ Spring Boot 电商用户复购预测案例中相关概念
java·人工智能·spring boot·后端·spring
goodluckyaa39 分钟前
LCR 006. 两数之和 II - 输入有序数组
算法
孤狼warrior40 分钟前
YOLO目标检测 一千字解析yolo最初的摸样 模型下载,数据集构建及模型训练代码
人工智能·python·深度学习·算法·yolo·目标检测·目标跟踪
Java后端的Ai之路1 小时前
【Spring全家桶】-一文弄懂Spring Cloud Gateway
java·后端·spring cloud·gateway