鱼C论坛

 找回密码
 立即注册
查看: 1132|回复: 10

[已解决]大佬帮忙看看顺便讲一下算法

[复制链接]
发表于 2022-3-22 15:14:35 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
运动会上,两个班级在为场上的运动员鼓掌加油。其中A班的同学每x秒钟鼓掌一次,B班的同学每y秒钟鼓掌一次,每次鼓掌都持续1秒钟。这样的话,在n秒钟之内,共有多少秒的时间有掌声?
x=2,y=3,n=10的情况如下:
最佳答案
2022-3-22 20:11:40

因为你没有说最大值是多少,如果是超级大的值,这种题目必须说明清楚,因为普通代码行不通的,大多数需要数学知识。试试这个吧,因为我没有参数,所以无法测试对错:
#include <stdio.h>

int gcd (int a, int b) { return !b ? a : gcd(b, a%b); }
int lcm (int a, int b) { return (a / gcd(a, b)) * b; }

int main(){
    
    int x, y, z, n, a, b, sum = 0;
    scanf("%d%d%d", &x, &y, &n);
    
    z = lcm(x, y);
    a = (z/x + z/y - 1)*(n / z);
    b = (n % z)/x + (n % z)/y;
    
    sum = a + b;
    
    printf("%d", sum);
    
    return 0;
}
ef6bdd2cf773536a84c91a2dd164a2e6.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-3-22 16:19:54 From FishC Mobile | 显示全部楼层
#include <stdio.h>

int main(){
        int x, y, n, sum = 0;
        scanf("%d%d%d", &x, &y, &n);
        for(int i = 1; i <= n; i++){
                if(!(i%x) && !(i%y)) sum++;
                else if(!(i%x) || !(i%y)) sum++;
        }
        printf("%d", sum);
        return 0;
}
2 3 10
7
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-3-22 18:22:41 | 显示全部楼层

借花献佛
#include <stdio.h>

int main(){
        int x, y, n, sum = 0;
        scanf("%d%d%d", &x, &y, &n);
        for(int i = 1; i <= n; i++){
                 if(!(i%x) || !(i%y)) sum++;
        }
        printf("%d", sum);
        return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-3-22 18:28:10 | 显示全部楼层

真是厉害,被你点醒了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-3-22 18:35:17 | 显示全部楼层

#include<stdio.h>

int main()
{
    int x, y, n,sn;
    scanf_s("%d %d %d", &x, &y, &n);
    sn = n / x + n / y - n / (x * y);
    printf("%d", sn);

    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2022-3-22 19:27:34 | 显示全部楼层
rfl 发表于 2022-3-22 18:35
#include

int main()

部分测试集正确
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-3-22 19:30:12 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-3-22 19:47:28 | 显示全部楼层

n 最大是多少?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-3-22 20:11:40 | 显示全部楼层    本楼为最佳答案   

因为你没有说最大值是多少,如果是超级大的值,这种题目必须说明清楚,因为普通代码行不通的,大多数需要数学知识。试试这个吧,因为我没有参数,所以无法测试对错:
#include <stdio.h>

int gcd (int a, int b) { return !b ? a : gcd(b, a%b); }
int lcm (int a, int b) { return (a / gcd(a, b)) * b; }

int main(){
    
    int x, y, z, n, a, b, sum = 0;
    scanf("%d%d%d", &x, &y, &n);
    
    z = lcm(x, y);
    a = (z/x + z/y - 1)*(n / z);
    b = (n % z)/x + (n % z)/y;
    
    sum = a + b;
    
    printf("%d", sum);
    
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2022-3-23 15:41:23 | 显示全部楼层

十万呢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-3-23 17:22:10 | 显示全部楼层


你可以试试我的代码:我测试一千万,没有问题,不到半秒
2 3 10000000
6666667
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-18 04:39

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表