鱼C论坛

 找回密码
 立即注册
查看: 2745|回复: 21

[已解决]时间超时

[复制链接]
发表于 2021-3-19 19:07:44 | 显示全部楼层 |阅读模式

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

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

x
蓝桥杯上的一道题,总是说时间超时,难道还有更简单的写法?!
提示:时间超限:运行超出时间限制,请检查是否有死循环或程序算法效率低。
[code]#include <stdio.h>

int main(void)
{
       
        int n, k, T, i = 1, j;
        int sum = 1, count = 1, num = 1;
        scanf("%d %d %d", &n, &k, &T);
       
        for(j = 1; j <= n; ++j)
        {
                if(i == T)
                {
                        break;
                }
               
                num += count;
                count++;
                if(num > k)
                {
                        num = num + count - k;
                }
               
               
                if(j == n)
                {
                        sum += num;
                        i++;
                        j = 1;
                }
        }
       
        printf("%d", sum);
        return 0;
} [\code]
最佳答案
2021-3-19 20:50:21
本帖最后由 baige 于 2021-3-19 20:51 编辑

这一种比上一种简单,溢出处理也比较容易,也是等差数列求和
  1. #include <stdio.h>
  2. #define LL long long int

  3. int main(void) {
  4.         int i = 1;
  5.         LL sum = 1, x, add = 1, n, k, t;
  6.         scanf("%lld%lld%lld",&n,&k,&t);
  7.         while (i < t) {
  8.                 x = add + ((i-1)*n + 1 + i*n)*n/2; // 得到这次这个人所报的数字

  9.                 i++;  // 过这个人的次数加1
  10.                 x = x % k; //当大于k的部分需要返回
  11.                 sum += x; //数字和
  12.                 add = x; // 返回
  13.         }
  14.         printf("%lld",sum);
  15.         return 0;
  16. }
复制代码
QQ图片20210319190724.png
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-3-19 19:30:53 | 显示全部楼层
太难了,头发又掉了两根。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-3-19 19:42:53 | 显示全部楼层
本帖最后由 baige 于 2021-3-19 20:08 编辑

C++不想写了溢出
思路:https://wenda.so.com/q/1383384369068994
  1. n, k, t = input().split()
  2. n, k, t = int(n), int(k), int(t);
  3. ans = 1
  4. for i in range(1, t):
  5.     ans += ((i*n+1)*(i*n)//2+1)%k
  6. print(ans)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-3-19 20:09:24 | 显示全部楼层
baige 发表于 2021-3-19 19:42
C++不想写了溢出
思路:https://wenda.so.com/q/1383384369068994

这是考的数学还是编程啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-3-19 20:16:51 | 显示全部楼层
别的比赛数学更难
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-3-19 20:50:21 | 显示全部楼层    本楼为最佳答案   
本帖最后由 baige 于 2021-3-19 20:51 编辑

这一种比上一种简单,溢出处理也比较容易,也是等差数列求和
  1. #include <stdio.h>
  2. #define LL long long int

  3. int main(void) {
  4.         int i = 1;
  5.         LL sum = 1, x, add = 1, n, k, t;
  6.         scanf("%lld%lld%lld",&n,&k,&t);
  7.         while (i < t) {
  8.                 x = add + ((i-1)*n + 1 + i*n)*n/2; // 得到这次这个人所报的数字

  9.                 i++;  // 过这个人的次数加1
  10.                 x = x % k; //当大于k的部分需要返回
  11.                 sum += x; //数字和
  12.                 add = x; // 返回
  13.         }
  14.         printf("%lld",sum);
  15.         return 0;
  16. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-3-19 20:52:31 | 显示全部楼层
错误太多,边界,步距,循环次数,大部分都错了

  1. #include <stdio.h>

  2. int main(void)
  3. {
  4.     //int n, k, T, i = 1, j;
  5.     int n, k, T, i = 0, j;
  6.     //int sum = 1, count = 1, num = 1;
  7.     int sum = 0, count = 1, num = 1;
  8.     scanf("%d %d %d", &n, &k, &T);

  9.     //for(j = 1; j <= n; ++j)
  10.     for(j = 0; j <= n; ++j)
  11.     {
  12.         if(i == T)
  13.         {
  14.             break;
  15.         }

  16.         //num += count;
  17.         //count++;
  18.         if(num > k)
  19.         {
  20.             //num = num + count - k;
  21.             num = num - k;
  22.         }


  23.         //if(j == n)
  24.         if(j == 0 || j == n)
  25.         {
  26.             sum += num;
  27.             i++;
  28.             //j = 1;
  29.             j = 0;
  30.         }

  31.         num += count;
  32.         count++;
  33.     }

  34.     printf("%d", sum);
  35.     return 0;
  36. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-3-19 20:53:02 | 显示全部楼层
  1. #include <stdio.h>
  2. int main()
  3. {
  4.     int n, k, T;
  5.     long long sum = 1, t=1, a=1;
  6.     scanf("%d%d%d", &n, &k, &T);
  7.     int i;
  8.     for(i = 1; i < T; ++i)
  9.     {
  10.         t = (((a+a+n-1)*n/2)+t)%k;
  11.         sum += t;
  12.         a += n;
  13.     }
  14.     printf("%lld\n", sum);
  15.     return 0;
  16. }
复制代码

评分

参与人数 1荣誉 +3 鱼币 +5 收起 理由
巴巴鲁 + 3 + 5 鱼C有你更精彩^_^

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-3-19 21:06:38 | 显示全部楼层
  1. #include <stdio.h>

  2. int main(void) {
  3.     size_t n, k, T;
  4.     size_t sum = 0, num = 1, count = 1;
  5.     scanf("%lu%lu%lu", &n, &k, &T);
  6.     for(size_t i = 0; i < T; ++i) {
  7.         sum += num;
  8.         for(size_t j = 0; j < n; ++j) {
  9.             num += count++;
  10.             if(num >= k) num = num - k;
  11.         }
  12.     }
  13.     printf("%lu\n", sum);
  14.     return 0;
  15. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-3-19 22:20:26 | 显示全部楼层
zip... 发表于 2021-3-19 19:30
太难了,头发又掉了两根。

这个不难,难就难在使代码最高效
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-3-19 22:23:26 | 显示全部楼层
人造人 发表于 2021-3-19 20:52
错误太多,边界,步距,循环次数,大部分都错了

没有吧,我初始条件就赋值1,j开始少循环一次,
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-3-19 22:24:24 | 显示全部楼层
人造人 发表于 2021-3-19 20:52
错误太多,边界,步距,循环次数,大部分都错了

关键是超时,好像要是最高效的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-3-19 22:24:58 | 显示全部楼层

楼上先发的,就把最佳给他了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-3-19 23:58:13 | 显示全部楼层
巴巴鲁 发表于 2021-3-19 22:24
关键是超时,好像要是最高效的
  1. #include <stdio.h>

  2. int main(void)
  3. {

  4.     int n, k, T, i = 1, j;
  5.     int sum = 1, count = 1, num = 1;
  6.     scanf("%d %d %d", &n, &k, &T);

  7.     for(j = 1; j <= n; ++j)
  8.     {
  9.         if(i == T)
  10.         {
  11.             break;
  12.         }

  13.         num += count;
  14.         count++;
  15.         if(num > k)
  16.         {
  17.             num = num + count - k;
  18.         }


  19.         printf("%d\n", num);
  20.         if(j == n)
  21.         {
  22.             printf("    %d\n", num);
  23.             sum += num;
  24.             i++;
  25.             j = 1;
  26.         }
  27.     }

  28.     printf("%d", sum);
  29.     return 0;
  30. }
复制代码

  1. 3 13 3
  2. 2
  3. 4
  4. 7
  5.     7
  6. 11
  7. 9
  8.     9
复制代码


  1. #include <stdio.h>

  2. int main(void)
  3. {
  4.     //int n, k, T, i = 1, j;
  5.     int n, k, T, i = 0, j;
  6.     //int sum = 1, count = 1, num = 1;
  7.     int sum = 0, count = 1, num = 1;
  8.     scanf("%d %d %d", &n, &k, &T);

  9.     //for(j = 1; j <= n; ++j)
  10.     for(j = 0; j <= n; ++j)
  11.     {
  12.         if(i == T)
  13.         {
  14.             break;
  15.         }

  16.         //num += count;
  17.         //count++;
  18.         if(num > k)
  19.         {
  20.             //num = num + count - k;
  21.             num = num - k;
  22.         }


  23.         printf("%d\n", num);
  24.         //if(j == n)
  25.         if(j == 0 || j == n)
  26.         {
  27.             printf("    %d\n", num);
  28.             sum += num;
  29.             i++;
  30.             //j = 1;
  31.             j = 0;
  32.         }

  33.         num += count;
  34.         count++;
  35.     }

  36.     printf("%d", sum);
  37.     return 0;
  38. }
复制代码

  1. 3 13 3
  2. 1
  3.     1
  4. 2
  5. 4
  6. 7
  7.     7
  8. 11
  9. 3
  10. 9
  11.     9
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-3-20 00:05:20 | 显示全部楼层
提问,为什么这3个程序的输出不一样?


  1. #include <stdio.h>

  2. int main(void)
  3. {
  4.       
  5.         int n, k, T, i = 1, j;
  6.         int sum = 1, count = 1, num = 1;
  7.         scanf("%d %d %d", &n, &k, &T);
  8.       
  9.         for(j = 1; j <= n; ++j)
  10.         {
  11.                 if(i == T)
  12.                 {
  13.                         break;
  14.                 }
  15.                
  16.                 num += count;
  17.                 count++;
  18.                 if(num > k)
  19.                 {
  20.                         num = num + count - k;
  21.                 }
  22.                
  23.                
  24.                 if(j == n)
  25.                 {
  26.                         sum += num;
  27.                         i++;
  28.                         j = 1;
  29.                 }
  30.         }
  31.       
  32.         printf("%d", sum);
  33.         return 0;
  34. }
复制代码
  1. 4 14 4
  2. 57
复制代码


  1. #include <stdio.h>

  2. int main(void)
  3. {
  4.     //int n, k, T, i = 1, j;
  5.     int n, k, T, i = 0, j;
  6.     //int sum = 1, count = 1, num = 1;
  7.     int sum = 0, count = 1, num = 1;
  8.     scanf("%d %d %d", &n, &k, &T);

  9.     //for(j = 1; j <= n; ++j)
  10.     for(j = 0; j <= n; ++j)
  11.     {
  12.         if(i == T)
  13.         {
  14.             break;
  15.         }

  16.         //num += count;
  17.         //count++;
  18.         if(num > k)
  19.         {
  20.             //num = num + count - k;
  21.             num = num - k;
  22.         }


  23.         //if(j == n)
  24.         if(j == 0 || j == n)
  25.         {
  26.             sum += num;
  27.             i++;
  28.             //j = 1;
  29.             j = 0;
  30.         }

  31.         num += count;
  32.         count++;
  33.     }

  34.     printf("%d", sum);
  35.     return 0;
  36. }
复制代码
  1. 4 14 4
  2. 30
复制代码


  1. #include <stdio.h>
  2. #define LL long long int

  3. int main(void) {
  4.         int i = 1;
  5.         LL sum = 1, x, add = 1, n, k, t;
  6.         scanf("%lld%lld%lld",&n,&k,&t);
  7.         while (i < t) {
  8.                 x = add + ((i-1)*n + 1 + i*n)*n/2; // 得到这次这个人所报的数字

  9.                 i++;  // 过这个人的次数加1
  10.                 x = x % k; //当大于k的部分需要返回
  11.                 sum += x; //数字和
  12.                 add = x; // 返回
  13.         }
  14.         printf("%lld",sum);
  15.         return 0;
  16. }
复制代码
  1. 4 14 4
  2. 30
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-3-20 13:02:11 | 显示全部楼层
人造人 发表于 2021-3-20 00:05
提问,为什么这3个程序的输出不一样?

啊,抱歉,我思路有问题
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-3-21 21:45:24 | 显示全部楼层
哈哈,你也要考蓝桥杯啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-3-22 14:25:39 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-3-23 12:28:54 | 显示全部楼层
yayc_zcyd 发表于 2021-3-21 21:45
哈哈,你也要考蓝桥杯啊

哈哈,是的,同道中人吗?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-3-23 19:14:24 | 显示全部楼层
巴巴鲁 发表于 2021-3-23 12:28
哈哈,是的,同道中人吗?

必须的,但是我发现蓝桥杯考的几乎全是算法
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-30 18:13

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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