微众银行笔试第三题,
有没有大佬帮我看一下为啥一个用例都过不了
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int main()
{
int n, u, v;
cin >> n >> u >> v;
vector<int> a(n + 1);
vector<int> presum(n + 1);
presum[0] = 0;
a[0] = 0;
for (int i = 1; i <= n; i++)
{
cin >> a[i];
presum[i] = presum[i - 1] + a[i];
}
int count = 0;
for (int i = 1; i <= n; i++)
{
for (int j = i; j <= n; j++)
{
int sum = presum[j] - presum[i - 1];
if ((sum / (j - i + 1)) == u / v)
count += 1;
}
}
cout << count;
return 0;
}
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int main()
{
int n, u, v;
cin >> n >> u >> v;
vector<int> a(n + 1);
vector<int> presum(n + 1);
presum[0] = 0;
a[0] = 0;
for (int i = 1; i <= n; i++)
{
cin >> a[i];
presum[i] = presum[i - 1] + a[i];
}
int count = 0;
for (int i = 1; i <= n; i++)
{
for (int j = i; j <= n; j++)
{
int sum = presum[j] - presum[i - 1];
if ((sum / (j - i + 1)) == u / v)
count += 1;
}
}
cout << count;
return 0;
}
全部评论
别用除法用乘法
思路没错吧,但是你要知道整数除***下取整,有理数也有可能是小数
相关推荐
点赞 评论 收藏
分享
原来感觉美团一面回答还可以的,大部分都回答出来了,但已经快三天没消息了,今天实在忍不住,主动发短信问面试官,结果担心的事还是发生了,还是挂了,希望明天进人才库很快就有人捞我今晚回来马上继续怒投6家公司
hit鸟渣渣:我也是,闪购部门,八股盛宴但几乎都答,手撕也没卡顿,三天进人才库然后感谢信
点赞 评论 收藏
分享