时间限制: 1000ms
空间限制: 262144kB
题目描述
时间:1s 空间:256M
题目描述:
有n个人,每个人都拥有一个喜悦值,接下来,任意三个人之间会进行一次交流,任意三个人交流所获得的贡献为三个人的喜悦值的和,求任意三个人交流所获得的贡献之和
输入格式:
第一行一个整数n
接下来n行,每行一个整数a,表示第i个人的喜悦值
输出格式:
按题目描述输出
样例输入1:
3
2
3
4
样例输出1:
9
约定:
n<=1000
1<=a<=10^100
不会写,有大佬教教吗?
2 个赞
有人会吗
1 个赞
和*(n-1)*(n-2)/2
1 个赞
不知道怎么写
1 个赞
你这方法好像用不了,a<=10的100次方,得用高精度
1 个赞
所以说到底怎么写啊
1 个赞
写了一天了
1 个赞
题库高精度第四题
1 个赞
写高精度啊,我想想
1 个赞
帮帮忙,感谢
1 个赞
这个公式是对的,所以这么写:
1.计算所有数的和,使用高精度(可使用 for
循环,while
循环等,不断输入不断计算)
2.高精度乘法,乘上 (n-1)*(n-2) 的积。当然,这个算式可用因式分解分为: n^2-n*2-n+2 = n^2-3*n+2 ,也就是可以算出 n^2-3*n+2 的结果,再进行高精度乘法。这道题的 n 范围为: n≤1000 ,所以明显支持这样计算,不会爆 int
。
3.高精度除法,除以 $2$,完事输出。
1 个赞
#include<bits/stdc++.h>
using namespace std;
string stu[1010];
string add(string sa,string sb){
string ans="";
int a[1010]={0},b[1010]={0},c[1010]={0};
int la=sa.size(),lb=sb.size();
int lc=max(la,lb);
for(int i=0;i<la;i++)a[i]=sa[la-1-i]-'0';
for(int i=0;i<lb;i++)b[i]=sb[lb-1-i]-'0';
for(int i=0;i<lc;i++){
c[i]+=(a[i]+b[i]);
c[i+1]+=c[i]/10;
c[i]%=10;
}
if(c[lc])lc++;
for(int i=lc-1;i>=0;i--)ans+=char(c[i]+48);
return ans;
}
string multiple(string a,string b){
string h="";
int c[10100]={0},d[10100]={0},s[20203]={0};
if(a=="0" || b=="0")return "0";
int len1=a.size();
int len2=b.size();
int len=len1+len2;
for(int i=0;i<len1;i++){
c[i]=a[len1-1-i]-'0';
}
for(int i=0;i<len2;i++){
d[i]=b[len2-1-i]-'0';
}
for(int i=0;i<len1;i++){
for(int j=0;j<len2;j++)
{
s[i+j]+=c[i]*d[j];
}
}
for(int i=0;i<len;i++){
s[i+1]+=s[i]/10;
s[i]%=10;
}
while(len>1 && !s[len-1])len--;
for(int i=len-1;i>=0;i--)h+=s[i]+'0';
return h;
}
int main(){
int n;
string ans;
cin>>n;
for(int i=1;i<=n;i++){
cin>>stu[i];
}
for(int i=1;i<=n-1;i++){
for(int j=i+1;j<=n;j++)
{
ans=add(ans,add(stu[i],stu[j]));
}
}
int num=((n-1)*(n-2))/2;
???
return 0;
}
1 个赞
这里不会写
1 个赞
怎么写
1 个赞
这一步就错了,需要用高精度输入,因为 1<a_i<10^{100}
1 个赞
string s1,s2;
cin>>s1>>s2;
是这样吗
差不多吧,用字符串读入然后读入前两个的时候算前两个,以此类推:
第一个数+第二个数 -》 一个和
一个和+第三个数 -》 第二个和
…
倒数第二个和+最后一个数 -》最后的和
1 个赞
#include<bits/stdc++.h>
using namespace std;
string stu[1010];
string add(string sa,string sb){
string ans="";
int a[1010]={0},b[1010]={0},c[1010]={0};
int la=sa.size(),lb=sb.size();
int lc=max(la,lb);
for(int i=0;i<la;i++)a[i]=sa[la-1-i]-'0';
for(int i=0;i<lb;i++)b[i]=sb[lb-1-i]-'0';
for(int i=0;i<lc;i++){
c[i]+=(a[i]+b[i]);
c[i+1]+=c[i]/10;
c[i]%=10;
}
if(c[lc])lc++;
for(int i=lc-1;i>=0;i--)ans+=char(c[i]+48);
return ans;
}
string multiple(string a,string b){
string h="";
int c[10100]={0},d[10100]={0},s[20203]={0};
if(a=="0" || b=="0")return "0";
int len1=a.size();
int len2=b.size();
int len=len1+len2;
for(int i=0;i<len1;i++){
c[i]=a[len1-1-i]-'0';
}
for(int i=0;i<len2;i++){
d[i]=b[len2-1-i]-'0';
}
for(int i=0;i<len1;i++){
for(int j=0;j<len2;j++)
{
s[i+j]+=c[i]*d[j];
}
}
for(int i=0;i<len;i++){
s[i+1]+=s[i]/10;
s[i]%=10;
}
while(len>1 && !s[len-1])len--;
for(int i=len-1;i>=0;i--)h+=s[i]+'0';
return h;
}
int main(){
int n;
string ans;
cin>>n;
string s1,s2;
cin>>s1>>s2;
for(int i=1;i<=n-1;i++){
for(int j=i+1;j<=n;j++)
{
ans=add(ans,add(s1[i],s2[j]));
}
}
int num=((n-1)*(n-2))/2;
所以这里写啥
return 0;
}
$ 不知道 $
1 个赞
那你会写吗