问题描述
- 问大神们一个C语言蓝桥杯的问题,跪求大神啊
-
加法变乘法我们都知道:1+2+3+ ... + 49 = 1225
现在要求你把其中两个不相邻的加号变成乘号,使得结果为2015比如:
1+2+3+...+10*11+12+...+27*28+29+...+49 = 2015
就是符合要求的答案。请你寻找另外一个可能的答案,并把位置靠前的那个乘号左边的数字提交(对于示例,就是提交10)。
注意:需要你提交的是一个整数,不要填写任何多余的内容。
#include "stdio.h"
void main()
{
int sum,r,s,t;//r--第一个乘号位置
//s--第二个乘号位置
sum=0;
for(r=1;r<=46;r++)
for(s=r+2;s<=48;s++)
{
for(t=1;t<=49;t++)
{
if(t
sum=sum+t;
if(t==r)
{
sum=sum+(t*(t+1));
t++;
}
if(t>r+1&&t
sum=sum+t;
if(t==s)
{
sum=sum+(t*(t+1));
t++;
}
if(t>s+1) sum=sum+t;
}
if(sum==2015)
printf("%dn",r);
}
}
请问为什么我的程序运行不出结果,为什么我没有sum=2015的结果
解决方案
我觉得你的for循环少了一步sum的重置0
#include "stdio.h"
int main()
{
int sum,r,s,t;//r--第一个乘号位置
//s--第二个乘号位置
sum=0;
for(r=1;r<=46;r++)
for(s=r+2;s<=48;s++)
{
for(t=1;t<=49;t++)
{
if(t<r)sum=sum+t;
if(t==r)
{
sum=sum+(t*(t+1));
t++;
}
if(t>r+1 && t<s) sum=sum+t;
if(t==s)
{
sum=sum+(t*(t+1));
t++;
}
if(t>s+1) sum=sum+t;
}
if(sum==2015)
printf("%dn",r);
//重置为0
sum=0;
}
return 0;
}
得到结果
10
16