|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
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;
}
不知道哪有问题,提交作业后显示答案错误,但是按照输入样例是没错的
本帖最后由 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>
复制代码
|
|