2014年第五届蓝桥杯C/C++程序设计本科B组省赛

vv萌新一个!

(1)啤酒与饮料

题目描述

啤酒每罐2.3元,饮料每罐1.9元。小明买了若干啤酒和饮料,一共花了82.3元。
我们还知道他买的啤酒比饮料的数量少,请你计算他买了几罐啤酒。
注意:答案是一个整数。请通过浏览器提交答案。
不要书写任何多余的内容(例如:写了饮料的数量,添加说明文字等)。

这个题目很简单,思路是这样的:
我们先设啤酒和饮料分别为x和y,根据题目,可以得出y关于x的关系式,由x的关系式代替y。因为x要小于y,上代码:

#include<stdio.h>
int main()
{
	int x,y,i,m;
	for(x=1;;x++)
	{
	    y=(82.3-2.3*x)/1.9;
		if(y>x&&y==(82.3-2.3*x)/1.9)
		break;
    }
    printf("%d",x);
} 

总结:
数学功底还得过硬!

(2)切面条

题目描述

一根高筋拉面,中间切一刀,可以得到2根面条。

如果先对折1次,中间切一刀,可以得到3根面条。

如果连续对折2次,中间切一刀,可以得到5根面条。

那么,连续对折10次,中间切一刀,会得到多少面条呢?
答案是个整数,请通过浏览器提交答案。不要填写任何多余的内容。

这个题目刚开始我以为是斐波那契数列,
后面求第三次对折错了,发现这是另一个数列关系:第0次对折,一切,2条;第1次对折,切,3条;第2次对折,切,5条;第3次对折,切,9条…根据这个关系可以得出:该项==前一项*2-1。
上代码:

#include<stdio.h>
 int main()
 {
 	int i,z[11];
 	z[0]=2;
 	for(i=1;i<11;i++)
 	{
 		z[i]=z[i-1]*2-1;
	}
	printf("%d",z[10]);
	return 0;
 }

总结:不能太过于武断的去判断一个题目,需要观察一点时间去分析,去了解这个题目。

(3)李白打酒

话说大诗人李白,一生好饮。幸好他从不开车。
一天,他提着酒壶,从家里出来,酒壶中有酒2斗。他边走边唱:
无事街上走,提壶去打酒。
逢店加一倍,遇花喝一斗。
这一路上,他一共遇到店5次,遇到花10次,已知最后一次遇到的是花,他正好把酒喝光了。
请你计算李白遇到店和花的次序,可以把遇店记为a,遇花记为b。则:babaabbabbabbbb 就是合理的次序。像这样的答案一共有多少呢?请你计算出所有可能方案的个数(包含题目给出的)。

这个题目我一看就想到了13年蓝桥杯“第39阶梯”的那个思路-----dfs。
上代码:

#include<stdio.h>
int sum=0;
void dfs(int d,int h,int j)///d是店,h是花,j是酒。
{
	if(d==0&&h==0&&j==1)因为李白最后一次遇到的是花,且函数开头为dfs(5,9,2)。
	sum++;
	if(d>0)
	dfs(d-1,h,j*2);
	if(h>0)
	dfs(d,h-1,j-1);
}
int main()
{
	dfs(5,9,2);
	printf("%d",sum);
	return 0;
}

(4)史丰收速算

史丰收速算
史丰收速算法的革命性贡献是:从高位算起,预测进位。不需要九九表,彻底颠覆了传统手算!
速算的核心基础是:1位数乘以多位数的乘法。
其中,乘以7是最复杂的,就以它为例。
因为,1/7 是个循环小数:0.142857…,如果多位数超过 142857…,就要进1
同理,2/7, 3/7, … 6/7 也都是类似的循环小数,多位数超过 n/7,就要进n
下面的程序模拟了史丰收速算法中乘以7的运算过程。
乘以 7 的个位规律是:偶数乘以2,奇数乘以2再加5,都只取个位。
乘以 7 的进位规律是:
满 142857… 进1,
满 285714… 进2,
满 428571… 进3,
满 571428… 进4,
满 714285… 进5,
满 857142… 进6
请分析程序流程,填写划线部分缺少的代码。

//计算个位 
int ge_wei(int a)
{
if(a % 2 == 0)
return (a * 2) % 10;
else
return (a * 2 + 5) % 10;
}
 
//计算进位 
int jin_wei(char* p)
{
char* level[] = {
"142857",
"285714",
"428571",
"571428",
"714285",
"857142"
};
 
char buf[7];
buf[6] = '\0';
strncpy(buf,p,6);
 
int i;
for(i=5; i>=0; i--){
int r = strcmp(level[i], buf);
if(r<0) return i+1;
while(r==0){
p += 6;
strncpy(buf,p,6);
r = strcmp(level[i], buf);
if(r<0) return i+1;
______________________________;  //填空
}
}
 
return 0;
}
 
//多位数乘以7
void f(char* s) 
{
int head = jin_wei(s);
if(head > 0) printf("%d", head);
 
char* p = s;
while(*p){
int a = (*p-'0');
int x = (ge_wei(a) + jin_wei(p+1)) % 10;
printf("%d",x);
p++;
}
 
printf("\n");
}
 
int main()
{
f("428571428571");
f("34553834937543");
return 0;
}

这个没看懂题目意思,不会。。。。。。。。。

(5)打印图形

小明在X星球的城堡中发现了如下图形和文字:

rank=3
   * 
  * * 
 *   *  
* * * *

rank=5
               *                                                      
              * *                                                     
             *   *                                                    
            * * * *                                                   
           *       *                                                  
          * *     * *                                                 
         *   *   *   *                                                
        * * * * * * * *                                               
       *               *                                              
      * *             * *                                             
     *   *           *   *                                            
    * * * *         * * * *                                           
   *       *       *       *  
  * *     * *     * *     * *  
 *   *   *   *   *   *   *   * 
* * * * * * * * * * * * * * * *  

ran=6
                               *                                      
                              * *                                     
                             *   *                                    
                            * * * *                                   
                           *       *                                  
                          * *     * *                                 
                         *   *   *   *                                
                        * * * * * * * *                               
                       *               *                              
                      * *             * *                             
                     *   *           *   *                            
                    * * * *         * * * *                           
                   *       *       *       *                          
                  * *     * *     * *     * *                         
                 *   *   *   *   *   *   *   *                        
                * * * * * * * * * * * * * * * *                       
               *                               *                      
              * *                             * *                     
             *   *                           *   *                    
            * * * *                         * * * *                   
           *       *                       *       *                  
          * *     * *                     * *     * *                 
         *   *   *   *                   *   *   *   *                
        * * * * * * * *                 * * * * * * * *               
       *               *               *               *              
      * *             * *             * *             * *             
     *   *           *   *           *   *           *   *            
    * * * *         * * * *         * * * *         * * * *           
   *       *       *       *       *       *       *       *          
  * *     * *     * *     * *     * *     * *     * *     * *         
 *   *   *   *   *   *   *   *   *   *   *   *   *   *   *   *        
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

小明开动脑筋,编写了如下的程序,实现该图形的打印。

#define N 70

void f(char a[][N], int rank, int row, int col)
{
	if(rank==1){
		a[row][col] = '*';
		return;
	}
	
	int w = 1;
	int i;
	for(i=0; i<rank-1; i++) w *= 2;
	
	____________________________________________;
	f(a, rank-1, row+w/2, col);
	f(a, rank-1, row+w/2, col+w);
}

int main()
{
	char a[N][N];
	int i,j;
	for(i=0;i<N;i++)
	for(j=0;j<N;j++) a[i][j] = ' ';
	
	f(a,6,0,0);
	
	for(i=0; i<N; i++){
		for(j=0; j<N; j++) printf("%c",a[i][j]);
		printf("\n");
	}
	
	return 0;
}

请仔细分析程序逻辑,填写缺失代码部分。

通过浏览器提交答案。注意不要填写题目中已有的代码。也不要写任何多余内容(比如说明性的文字)

刚开始看有点懵,没搞懂这是啥意思,后面根据图形关系得出(这是一个他们说是比较简单的递推函数):(我用代码的形式表达出我在纸上面画出的图形)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
首先这个函数求的是第几行第几列的⭐。
rank==
1是一颗星,2是三颗星,3是九颗星,…
后来我想到我高中一个方法,带入法。我将rank==2代进去,得出:
(1)f(a, rank-1, row+w/2, col);这个函数求的是行为1,列为0的⭐;
(2)f(a, rank-1, row+w/2, col+w);这个函数求的是行为1,列为2的⭐;
那么剩下的那一空,就是求行为0,列为1的⭐
所以答案就是:f(a, rank - 1, row, col + w / 2);

总结:有些题目可以用简单的方法去解决。

(6)奇怪的分式

上小学的时候,小明经常自己发明新算法。一次,老师出的题目是:
1/4 乘以 8/5
小明居然把分子拼接在一起,分母拼接在一起,答案是:18/45 (参见图1.png)
老师刚想批评他,转念一想,这个答案凑巧也对啊,真是见鬼!
对于分子、分母都是 1~9 中的一位数的情况,还有哪些算式可以这样计算呢?
显然,交换分子分母后,例如:4/1 乘以 5/8 是满足要求的,这算做不同的算式。
但对于分子分母相同的情况,2/2 乘以 3/3 这样的类型太多了,不在计数之列!
请写出所有不同算式的个数(包括题中举例的)。

这个题目我想的比较麻烦,根据题目意思:
首先得出分子与分母不能相同这个关键性条件,其次求出两个分式的最大公约数,判断化简后两者是否相等,最后枚举出分子,分母1~9的各种情况。
上代码:

#include<stdio.h>
int s(int n,int m)
{
	int i,t;
	if(n<m)
	{
		t=n;
		n=m;
		m=t;
	}
	for(i=n;i>0;i--)
	{
		if(n%i==0&&m%i==0)
		break;
	}
	return i;
}
int main()
{
	int a[9]={1,2,3,4,5,6,7,8,9};
	int n,i,j,k,l,m,t,sum=0;
	int fz1,fm1,fz2,fm2;
	int a1,b1,a2,b2;
	int c,d;
	for(i=0;i<9;i++)
	{
		for(j=0;j<9;j++)
		{
			for(k=0;k<9;k++)
			{
				for(l=0;l<9;l++)
				{
					fz1=a[i];fm1=a[j];fz2=a[k];fm2=a[l];
					a1=fz1*fz2;b1=fm1*fm2;
					a2=fz1*10+fz2;b2=fm1*10+fm2;
					c=s(a1,b1);d=s(a2,b2);
					if(a1/c==a2/d&&b1/c==b2/d&&fz1!=fm1&&fz2!=fm2)
					{
					    sum++;
					}
				}
			}
		}
	}
	printf("%d",sum);
	return 0;
 } 

(7)六角填数

这个真不会。。。。。。。。。。。。

(8)蚂蚁感冒

蚂蚁感冒
长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 , 不能通过工程设置而省略常用头文件。
提交时,注意选择所期望的编译器类型。

这个题目我本来是想一个一个蚂蚁去进行计数,发现太麻烦了,而且得出的答案还是错误的。
这个思路是这样的,我们可以先看第一个感冒的蚂蚁:
如果它是向右走,那么它右边杆上向左走的蚂蚁一定会被感染(可以在纸写写),而当它与其他蚂蚁碰头向左走时(若没有碰头就就算了)它左边杆上向右走的蚂蚁一定会被感染。
同理,向左走也是一样。
上代码:

#include<stdio.h>
#include<math.h>
int a[1000000];
int main()
{
	int n,i,m,j,sum=1;
	scanf("%d",&n);
	for(i=0;i<n;i++)
	scanf("%d",&a[i]);
	m=a[0];//第一只被感冒的蚂蚁。
	if(m>0)///向右
	{
		for(i=0;i<n;i++)
		{
			if(a[i]<0&&abs(a[i])>m)
			sum++;
		}
		if(sum>1)
		{
			for(i=0;i<n;i++)
			{
				if(a[i]>0&&-m<a[i])
				sum++;
			}
		}
	}
	else if(m<0)/向左
	{
		for(i=0;i<n;i++)
		{
			if(a[i]>0&&a[i]<abs(m))
			sum++;
		}
		if(sum>1)
		{
			for(i=0;i<n;i++)
			{
				if(a[i]<0&&abs(a[i])>abs(m))
				sum++;
			}
		}
	}
	printf("%d",sum);
	return 0;
}

总结:做题目需要思维活跃,不能太过于固化。

(9)地宫取宝

也没看懂啥意思。。。。。。。。。。

(10)小朋友排队

代码超时了。。。。。。。。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
2023的第十四届蓝桥杯 C/C++ 大学生大赛 A 省赛是一个非常重要且具有挑战性的比赛。作为蓝桥杯系列赛事的一部分,这个比赛吸引了全国各地的大学生参与,旨在促进青学生计算机编程技术的提高,培养他们的创新能力和团队协作精神。 参赛者需要通过线上报名,在规定的时间内上传自己的比赛作品。比赛设置了一系列难度逐渐增加的编程题目,要求选手运用C/C++语言进行编写和实现。这些题目可能涉及算法设计、数据结构、编程基础等方面的知识,考察参赛者的编码能力、解决问题的能力以及在压力下的应变能力。 在比赛中,选手不仅需要具备扎实的编程技术,还需要在有限的时间内迅速分析问题、设计解决方案,并通过编程实现。因此,参赛者需要具备良好的逻辑思维能力、数学基础和编程实践经验。 在省赛中取得好成绩的选手将有机会晋级到全国赛,进一步与全国各地的顶尖选手一较高下,争夺更好的名次和更多的奖品。 参加蓝桥杯 C/C++ 大学生大赛不仅是一次锻炼和展示自己编程能力的机会,还能结识更多志同道合的同学和业界精英,获得丰厚的奖金和荣誉。同时,参赛经历对于大学生未来的学习和职业发展也具有积极的影响。 总之,2023第十四届蓝桥杯 C/C++ 大学生大赛 A 省赛是一个具有挑战性的比赛,参赛者需要具备扎实的编程技术和解决问题的能力。通过参与比赛,学生可以提升自己的编程能力,拓宽视野,展示个人才华,并为未来的学习和就业打下坚实的基础。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值