2016年第七届蓝桥杯B组C/C++决赛题目

点击查看2016年第七届蓝桥杯B组C/C++决赛题解

1.一步之遥

 

 

2.凑平方数

 

 

3.棋子换位

  1. A棋子只能往右边移动,B棋子只能往左边移动。
  2. 每个棋子可以移动到相邻的空位。
  3. 每个棋子可以跳过相异的一个棋子落入空位(A跳过B或者B跳过A)。
#include <stdio.h>
#include <string.h> void move(char* data, int from, int to)
{
data[to] = data[from];
data[from] = '.';
} int valid(char* data, int k)
{
if(k<0 || k>=strlen(data)) return 0;
return 1;
} void f(char* data)
{
int i;
int tag;
int dd = 0; // 移动方向 while(1){
tag = 0;
for(i=0; i<strlen(data); i++){
if(data[i]=='.') continue;
if(data[i]=='A') dd = 1;
if(data[i]=='B') dd = -1; if(valid(data, i+dd) && valid(data,i+dd+dd)
&& data[i+dd]!=data[i] && data[i+dd+dd]=='.'){
//如果能跳...
move(data, i, i+dd+dd);
printf("%s\n", data);
tag = 1;
break;
}
} if(tag) continue; for(i=0; i<strlen(data); i++){
if(data[i]=='.') continue;
if(data[i]=='A') dd = 1;
if(data[i]=='B') dd = -1; if(valid(data, i+dd) && data[i+dd]=='.'){
// 如果能移动...
if( ______________________ ) continue; //填空位置
move(data, i, i+dd);
printf("%s\n", data);
tag = 1;
break;
}
} if(tag==0) break;
}
} int main()
{
char data[] = "AAA.BBB";
f(data);
return 0;
}

 

 

4.机器人塔

5.广场舞

2016年蓝桥杯B组C/C++决赛题目-LMLPHP

2016年蓝桥杯B组C/C++决赛题目-LMLPHP

6.生成树计数

2016年蓝桥杯B组C/C++决赛题目-LMLPHP

 

 

05-11 09:15