整体来说不算难,只不过用循环来操作可能会超出时间限制,这种问题可以用一个公式解决:sum=(n+1)*n/2。
以下是1+2+3...sum的代码(∧_∧):
#include<bits/stdc++.h>
using namespace std;
int main() {
unsigned long long int sum=0,n;
cin>>n;//输入一个数n
sum=(1+n)*n/2;//一种巧妙算法,能够代替for循环,可尝试理解一下
cout<<sum;//最后输出sum
}//看了我的代码,就点个赞呗(不多,就一个赞)!!!
如果是1+2+3...+10^sum呢,很简单,建立一个变量f,f就负责求10^sum,最后将公式中的n改为f就可以了(注意!不建议用以下代码,因为我的代码最大只能输入到18,到19就错了,所以要想支持到100000,必须高精度计算,(不过上面的代码可以支持到18位数,不用担心),所以 以下代码还需改进,谢谢? ??*。?(ˊ?ˋ*)??*。)。
以下是代码(︵_︵):
#include<bits/stdc++.h>
using namespace std;
int main() {
unsigned long long int f,sum=0,n;
cin>>n;//输入一个n
f=pow(10,n);//pow函数可以算次方pow(几的次方,几次方),或者用循环也行(不过f要等于1哦)。
sum=(1+f)*f/2;//将n改为f,算出累加结果
cout<<sum;//输出sum
}//看了我的代码,就点个赞呗(不多,就一个赞)!!!
这些就是我的代码(不是抄的哦!),有建议或错误就打在评论区,我会定期查看并修改,谢谢?*。?(ˊ?ˋ*)??*。? ? ? 。
|