首页 > 代码库 > 第五届蓝桥杯C/C++本科B组(真题试做)(6~8)
第五届蓝桥杯C/C++本科B组(真题试做)(6~8)
终于考完……不过挂科的铁定的了。
还是来做题吧。
前面八道题做起来都很简单。
F:
标题:奇怪的分式 上小学的时候,小明经常自己发明新算法。一次,老师出的题目是: 1/4 乘以 8/5 小明居然把分子拼接在一起,分母拼接在一起,答案是:18/45 (参见图1.png) 老师刚想批评他,转念一想,这个答案凑巧也对啊,真是见鬼! 对于分子、分母都是 1~9 中的一位数的情况,还有哪些算式可以这样计算呢? 请写出所有不同算式的个数(包括题中举例的)。 显然,交换分子分母后,例如:4/1 乘以 5/8 是满足要求的,这算做不同的算式。 但对于分子分母相同的情况,2/2 乘以 3/3 这样的类型太多了,不在计数之列! 注意:答案是个整数(考虑对称性,肯定是偶数)。请通过浏览器提交。不要书写多余的内容。
还是暴力就是了。答案是 14 。
#include<cstdio> #include<cstring> #include<string> #include<queue> #include<algorithm> #include<map> #include<stack> #include<iostream> #include<list> #include<set> #include<bitset> #include<vector> #include<cmath> #define INF 0x7fffffff #define eps 1e-8 #define LL long long #define PI 3.141592654 #define CLR(a,b) memset(a,b,sizeof(a)) #define FOR(i,a,b) for(int i=a;i<b;i++) #define FOR_(i,a,b) for(int i=a;i>=b;i--) #define pub push_back #define puf push_front #define pob pop_back #define pof pop_front #define mp make_pair #define ft first #define sd second #define sf scanf #define pf printf #define sz(v) ((int)(v).size()) #define all(v) (v).begin(),(v).end() #define acfun std::ios::sync_with_stdio(false) #define SIZE 10000 +1 using namespace std; int main() { int ans=0; FOR(i1,1,10) { FOR(j1,1,10) { if(i1==j1)continue; FOR(i2,1,10) { FOR(j2,1,10) { if(i2==j2)continue; double tmp1,tmp2; tmp1=i1/(j1*1.0)*(i2/(j2*1.0)); tmp2=(i1*10+i2)*1.0/((j1*10+j2)*1.0); //pf("%.2f %.2f\n",tmp1,tmp2); if(abs(tmp1-tmp2)<=eps)ans++; } } } } pf("%d\n",ans); }
G:
标题:六角填数 如图【1.png】所示六角形中,填入1~12的数字。 使得每条直线上的数字之和都相同。 图中,已经替你填好了3个数字,请你计算星号位置所代表的数字是多少? 请通过浏览器提交答案,不要填写多余的内容。
用一个数组表示为 a[12] 。
枚举一下就可以了,还是属于暴力。
答案是 10.
全部的12个数字是 1 8 9 2 7 10 12 6 5 4 11 3
bool vis[13]; int a[13]; bool cheack() { int tmp=a[1]+a[3]+a[6]+a[8]; if(a[1]+a[4]+a[7]+a[11]!=tmp)return 0; if(a[2]+a[3]+a[4]+a[5]!=tmp)return 0; if(a[8]+a[9]+a[10]+a[11]!=tmp)return 0; if(a[2]+a[6]+a[9]+a[12]!=tmp)return 0; if(a[5]+a[7]+a[10]+a[12]!=tmp)return 0; return 1; } void dfs(int i) { if(i==12) { if(!cheack())return; FOR(i,1,13) pf("%d ",a[i]); } FOR(j,1,13) { if(vis[j])continue; vis[j]=1; a[i]=j; dfs(i+1); vis[j]=0; } } int main() { a[1]=1,a[2]=8,a[12]=3; CLR(vis,0); vis[1]=1,vis[8]=1,vis[3]=1; dfs(3); }
H:
标题:蚂蚁感冒 长100厘米的细长直杆子上有n只蚂蚁。它们的头有的朝左,有的朝右。 每只蚂蚁都只能沿着杆子向前爬,速度是1厘米/秒。 当两只蚂蚁碰面时,它们会同时掉头往相反的方向爬行。 这些蚂蚁中,有1只蚂蚁感冒了。并且在和其它蚂蚁碰面时,会把感冒传染给碰到的蚂蚁。 请你计算,当所有蚂蚁都爬离杆子时,有多少只蚂蚁患上了感冒。 【数据格式】 第一行输入一个整数n (1 < n < 50), 表示蚂蚁的总数。 接着的一行是n个用空格分开的整数 Xi (-100 < Xi < 100), Xi的绝对值,表示蚂蚁离开杆子左边端点的距离。正值表示头朝右,负值表示头朝左,数据中不会出现0值,也不会出现两只蚂蚁占用同一位置。其中,第一个数据代表的蚂蚁感冒了。 要求输出1个整数,表示最后感冒蚂蚁的数目。 例如,输入: 3 5 -2 8 程序应输出: 1 再例如,输入: 5 -10 8 -20 12 25 程序应输出: 3 资源约定: 峰值内存消耗 < 256M CPU消耗 < 1000ms 请严格按要求输出,不要画蛇添足地打印类似:“请您输入...” 的多余内容。 所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。 注意: main函数需要返回0 注意: 只使用ANSI C/ANSI C++ 标准,不要调用依赖于编译环境或操作系统的特殊函数。 注意: 所有依赖的函数必须明确地在源文件中 #include <xxx>, 不能通过工程设置而省略常用头文件。 提交时,注意选择所期望的编译器类型。
把两只蚂蚁相撞当成没有碰过就好了。统计一下 前面相反的,如果有就加上后面相同的。
#include<cstdio> #include<cstring> #include<string> #include<queue> #include<algorithm> #include<map> #include<stack> #include<iostream> #include<list> #include<set> #include<bitset> #include<vector> #include<cmath> #define INF 0x7fffffff #define eps 1e-8 #define LL long long #define PI 3.141592654 #define CLR(a,b) memset(a,b,sizeof(a)) #define FOR(i,a,b) for(int i=a;i<b;i++) #define FOR_(i,a,b) for(int i=a;i>=b;i--) #define pub push_back #define puf push_front #define pob pop_back #define pof pop_front #define mp make_pair #define ft first #define sd second #define sf scanf #define pf printf #define sz(v) ((int)(v).size()) #define all(v) (v).begin(),(v).end() #define acfun std::ios::sync_with_stdio(false) #define SIZE 10000 +1 using namespace std; bool cheack(int a,int b) { if(a>0&&b<0)return 1; if(a<0&&b>0)return 1; return 0; } int main() { int n,a[51]; while(~sf("%d",&n)) { FOR(i,0,n) sf("%d",&a[i]); int l=0,r=0; int ans=0; FOR(i,0,n) { if(a[0]>0) { if(abs(a[i])>abs(a[0])&&cheack(a[0],a[i])) ans++; if(abs(a[i])<abs(a[0])&&cheack(-a[0],a[i])) ans++; } else { if(abs(a[i])<abs(a[0])&&cheack(a[0],a[i])) ans++; if(abs(a[i])>abs(a[0])&&cheack(-a[0],a[i])) ans++; } } pf("%d\n",ans+1); } }
至于后面两个题。一个应该是记忆化搜索,还有一个应该是求逆序,归并或者数状数组,先放个元旦,有空就做。
第五届蓝桥杯C/C++本科B组(真题试做)(6~8)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。