团体程序设计天梯赛——L1-008 求整数段和

团体程序设计天梯赛——L1-008 求整数段和

https://pintia.cn/problem-sets/994805046380707840/problems/994805135224455168

给定两个整数A和B,输出从A到B的所有整数以及这些数的和。

输入格式:

输入在一行中给出2个整数A和B,其中−100≤A≤B≤100,其间以空格分隔。

输出格式:

首先顺序输出从A到B的所有整数,每5个数字占一行,每个数字占5个字符宽度,向右对齐。最后在一行中按Sum = X的格式输出全部数字的和X。

输入样例:

-3 8

输出样例:

-3 -2 -1 0 1
2 3 4 5 6
7 8
Sum = 30

顺序输出和累加和都很好办,一个for循环,一个sum变量就可以解决,5个数字占一行也好办,对5的余数为零换行就可以了(注意这里要加一,否则第一行会输出6个数)。坑的是这个每个数字占5个字符宽度,向右对齐,需要判断这个数有几位,在前面填几个空格。于是我将它们分成了6段,分别在前面补上所需的空格。

#include
#include
using namespace std;
int main(){
	int a,b;
	cin>>a>>b;
	int min=a;
	int max=b;
	int j=0,sum=0;
	for(int i=min;i<=max;i++){
		j=0;
		sum+=i;
		if(i==-100) cout<<" ";
		if(i<=-10&&i>-100) cout<<"  ";
		if(i>-10&&i<0) cout<<"   ";
		if(i>=0&&i<10) cout<<"    ";
		if(i>=10&&i<100) cout<<"   ";
		if(i==100) cout<<"  ";
		cout<<i;
		if((i-min+1)%5==0){
			j=1;
			cout<<endl;
		} 
	}
	if(j==0) cout<<endl;
	cout<<"Sum = "<<sum<<endl;
}

你可能感兴趣的:(团体程序设计天梯赛)