鱼C论坛

 找回密码
 立即注册
查看: 1459|回复: 2

[已解决]求助!!!C语言求和问题

[复制链接]
发表于 2022-9-26 23:34:39 | 显示全部楼层 |阅读模式

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

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

x
题目如下:
编程求:sum(m,n)=m+(m+1)+...+(n−1)+(n)

输入格式:
多行输入,每一行均输入以空格隔开的两个正整数m和n。
输出格式:
每行输入对应一个正整数输出。

输入样例:
2 100
1 10000
输出样例:
5049
50005000

我的代码如下:
#include<stdio.h>
int main()
{
    int m,n,sum,sum2;
    scanf("%d %d",&m,&n);
    sum = 0;
    for(;m<=n;m++)
    {
        sum+=m;
    }
    sum2 = 0;
    scanf("%d %d",&m,&n);
    for(;m<=n;m++)
    {
        sum2+=m;
    }
    printf("%d\n\%d",sum,sum2);
   
    return 0;
}

不知道哪有问题,提交作业后显示答案错误,但是按照输入样例是没错的
最佳答案
2022-9-26 23:55:29
本帖最后由 jackz007 于 2022-9-27 00:48 编辑

      
多行输入,每一行均输入以空格隔开的两个正整数m和n。


       如此要求,如何结束输入,题目是如何要求的?
       同时接受多组输入,输出相应的多种结果,显然要用到数组。
       空回车结束方案:
#include <stdio.h>
#include <string.h>

int main(void)
{
        char s[2048]                                                                      ;
        unsigned long long d[2000][3] , i , j , k , n                                     ;
        for(n = 0 ;;) {
                fgets(s , 256 , stdin)                                                    ;
                k = strlen(s)                                                             ;
                if(k > 2 && (sscanf(s , "%I64u%I64u" , & d[n][0] , & d[n][1])) == 2) n ++ ;
                else break                                                                ;
        }        
        for(i = 0 ; i < n ; i ++) {
                if(d[i][1] > d[i][0]) {
                        for(d[i][2] = 0 , j = d[i][0] ; j <= d[i][1] ; j ++) d[i][2] += j ;
                        printf("%I64u\n" , d[i][2])                                       ;
                }
        }
}
        编译、运行实况:
D:\[00.Exerciese.2022]\C>g++ -o x x.c

D:\[00.Exerciese.2022]\C>x
2 100
1 10000

5049
50005000

D:\[00.Exerciese.2022]\C>
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-9-26 23:55:29 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2022-9-27 00:48 编辑

      
多行输入,每一行均输入以空格隔开的两个正整数m和n。


       如此要求,如何结束输入,题目是如何要求的?
       同时接受多组输入,输出相应的多种结果,显然要用到数组。
       空回车结束方案:
#include <stdio.h>
#include <string.h>

int main(void)
{
        char s[2048]                                                                      ;
        unsigned long long d[2000][3] , i , j , k , n                                     ;
        for(n = 0 ;;) {
                fgets(s , 256 , stdin)                                                    ;
                k = strlen(s)                                                             ;
                if(k > 2 && (sscanf(s , "%I64u%I64u" , & d[n][0] , & d[n][1])) == 2) n ++ ;
                else break                                                                ;
        }        
        for(i = 0 ; i < n ; i ++) {
                if(d[i][1] > d[i][0]) {
                        for(d[i][2] = 0 , j = d[i][0] ; j <= d[i][1] ; j ++) d[i][2] += j ;
                        printf("%I64u\n" , d[i][2])                                       ;
                }
        }
}
        编译、运行实况:
D:\[00.Exerciese.2022]\C>g++ -o x x.c

D:\[00.Exerciese.2022]\C>x
2 100
1 10000

5049
50005000

D:\[00.Exerciese.2022]\C>
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-9-27 06:57:14 | 显示全部楼层
本帖最后由 jhq999 于 2022-9-27 08:57 编辑
unsigned long long sum(unsigned long long m,unsigned long long n,unsigned long long distance=1)
{
        if(n>=m)return (m+n)*((n-m)/distance+1)/2;
        else return(m+n)*((m-n)/distance+1)/2;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-16 21:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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