1080 MOOC期终成绩 (25分)

作为一个菜鸡每次写完看柳婼的就更加觉得自己是个NC

先上自己的脑瘫代码

#include

#include

#include

#include

#include

#include <unordered_map>

#include

#include

using namespace std;

struct stu

{

string name;

int score;

};

bool cmp(stu a,stu b)

{

if(a.score!=b.score)

return a.score>b.score;

else

return a.name<b.name;

}

int main()

{

int p,m,n;

cin>>p>>m>>n;

map<string,int>P,M,N,flag1,flag2;

vectorper;

vectorsb;

string temp;int temp1;

for(int i=0;i<p;i++)

{

cin>>temp>>temp1;

P[temp]=temp1;

flag1[temp]=1;

per.push_back(temp);

}

for(int i=0;i<m;i++)

{

cin>>temp>>temp1;

M[temp]=temp1;

flag2[temp]=1;

if(flag1[temp]!=1)

{

P[temp]=-1;

per.push_back(temp);

}

}

for(int i=0;i<n;i++)

{

cin>>temp>>temp1;

N[temp]=temp1;

if(flag1[temp]!=1&&flag2[temp]!=1)

{

per.push_back(temp);

P[temp]=-1;

M[temp]=-1;

}

else if(flag1[temp]!=1&&flag2[temp]==1)

{

P[temp]=-1;

}

else if(flag1[temp]==1&&flag2[temp]!=1)

{

M[temp]=-1;

}

}

stu temp2;

for(int i=0;i<per.size();i++)

{

if(P[per[i]]<200)

;

else

{

if(M[per[i]]==-1)

{

if(N[per[i]]==-1||N[per[i]]<60)

continue;

else

{

temp2.name=per[i];

temp2.score=N[per[i]];

sb.push_back(temp2);

}

}

else if(M[per[i]]1&&N[per[i]]-1)

{

continue;

}

else

{

double su=0;

temp2.name=per[i];

if(M[per[i]]>N[per[i]])

su=(double)M[per[i]]*0.4+(double)N[per[i]]*0.6;

else

su=N[per[i]];

temp2.score=(int)(su+0.5);

if(temp2.score>=60)

sb.push_back(temp2);

}

}

}

sort(sb.begin(),sb.end(),cmp);

for(int i=0;i<sb.size();i++)

{

cout<<sb[i].name<<" “<<P[sb[i].name]<<” “<<M[sb[i].name]<<” “<<N[sb[i].name]<<” "<<sb[i].score<<endl;

}

return 0;

}

毫无技术含量,就是在记一个成绩时先看上一个成绩记了没有,如果没有就改为-1。

记一下柳婼大神的

#include
#include
#include
#include
using namespace std;
struct node {
string name;
int gp, gm, gf, g;
};
bool cmp(node a, node b) {
return a.g != b.g ? a.g > b.g : a.name < b.name;
}
map<string, int> idx;
int main() {
int p, m, n, score, cnt = 1;
cin >> p >> m >> n;
vector v, ans;
string s;
for (int i = 0; i < p; i++) {
cin >> s >> score;
if (score >= 200) {
v.push_back(node{s, score, -1, -1, 0});//直接用一个临时变量pushback
idx[s] = cnt++; //这个地方的idx就是记当前的人是在v里是几号
}
}
for (int i = 0; i < m; i++) {
cin >> s >> score;
if (idx[s] != 0) v[idx[s] - 1].gm = score;
}
for (int i = 0; i < n; i++) {
cin >> s >> score;
if (idx[s] != 0) {
int temp = idx[s] - 1;
v[temp].gf = v[temp].g = score;
if (v[temp].gm > v[temp].gf) v[temp].g = int(v[temp].gm * 0.4 + v[temp].gf * 0.6 + 0.5);
}
}
for (int i = 0; i < v.size(); i++)
if (v[i].g >= 60) ans.push_back(v[i]);
sort(ans.begin(), ans.end(), cmp);
for (int i = 0; i < ans.size(); i++)
printf("%s %d %d %d %d\n", ans[i].name.c_str(), ans[i].gp, ans[i].gm, ans[i].gf, ans[i].g);
return 0;
}

哎 自己怎么就学不会这种简单的思考方法呢。。。
太菜了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个简单的二查找的完整代码实现,该代码实现了在有序数组中查找指定元素的功能。 ```c++ #include <iostream> using namespace std; int binarySearch(int arr[], int left, int right, int x) { while (left <= right) { int mid = left + (right - left) / 2; // 如果 x 在中间 if (arr[mid] == x) return mid; // 如果 x 大于中间元素,只需要在右半部搜索 if (arr[mid] < x) left = mid + 1; // 如果 x 小于中间元素,只需要在左半部搜索 else right = mid - 1; } // 如果 x 没有在数组中找到,返回 -1 return -1; } int main() { int arr[] = { 2, 3, 4, 10, 40 }; int n = sizeof(arr) / sizeof(arr[0]); int x = 10; int result = binarySearch(arr, 0, n - 1, x); if (result == -1) cout << "元素不在数组中!"; else cout << "元素在数组中的索引为:" << result; return 0; } ``` 在上面的代码中,`binarySearch` 函数是实现二查找的主要函数。该函数接受四个参数:要搜索的数组 `arr`,搜索范围的左边界 `left`,搜索范围的右边界 `right`,以及要查找的元素 `x`。 函数使用一个 while 循环来查找元素,只要搜索范围还没有缩小到只包含一个元素,就继续执行循环。在每次循环中,函数会计算搜索范围的中间位置 `mid`。然后,函数会检查中间位置的元素是否等于要查找的元素。如果是,函数会返回中间位置的索引。 如果中间位置的元素小于要查找的元素,那么要查找的元素只可能出现在中间位置的右侧。因此,函数会将搜索范围的左边界移到中间位置的右边一位。如果中间位置的元素大于要查找的元素,那么要查找的元素只可能出现在中间位置的左侧。因此,函数会将搜索范围的右边界移到中间位置的左边一位。 如果在循环结束时还没有找到要查找的元素,函数会返回 -1,表示元素不在数组中。否则,函数会返回要查找的元素在数组中的索引。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值