题目描述如下:
给定某数字A(1≤A≤9)以及非负整数N(0≤N≤100000),求数列之和S=A+AA+AAA+⋯+AA⋯A(N个A)。例如A=1, N=3时,S=1+11+111=123。
输入格式:
输入数字A与非负整数N。
输出格式:
输出其N项数列之和S的值。
输入样例:
1 3
输出样例:
123
看到本题后,有了两种想法;
第一种:将基数字存为字符串,利用string 来增加字符串的长度 string str+=basestr;
然后将str转换为整型,与sum累和,再将sum存为字符串。
若用此种方法的话要使用到string->int 和 int->string,借此熟悉一下相关知识。
在c++中比较方便的是使用stringstream;
使用之前需要包含头文件string 和 sstream
#include <string>
#include <sstream>
string转int
int num;
string str;
stringstream stream1(str);
//stringstream stream1; stream1<<str; //将str写入
stream1>>num; //将流内的内容输出到num中
int转string
int num;
string str;
str = std::to_string(num); //将num转换为字符赋值给str 。 缺点是c++11才支持
但在实现的时候发现这条路走不通,因为无论怎么操作,都有可能超出int的范围。然后考虑用数组的方法。
第二种:因为每一位的数字都是相同的,考虑用数组的方法
1 1 1 1
1 1 1
1 1
1
st[0] = 4*1+rem(rem:余数)
st[1] = 3*1+rem
...依此类推
代码如下:
// 数列求和(加强版)
#include <iostream>
int st[1000000]; //存放数据的数组
using namespace std;
int main(){
int base;
cin>>base;
int num;
cin>>num;
if(num==0){ //若num为0,即前0项和,直接输出0返回
cout<<"0";
return 0;
}
int reminder = 0;
int cnt = 0;
for(int i=0;i<num;i++){
int temp = reminder + (num-i)*(base);
if(temp>9){ //若大于9,则产生余数
reminder = temp/10;
st[i] = temp%10;
cnt++;
}else{
reminder = 0;
st[i] = temp;
cnt++;
}
}
if(reminder>0){ //计算到最后还有余数,就让余数存在cnt的位置
st[cnt] = reminder;
cnt++;
}
for(int i=cnt-1;i>=0;i--){
cout<<st[i];
}
}