第五届蓝桥杯大赛个人赛(软件类)省赛真题

时间:2022-09-10 16:32:50

第一题

输入一个字符串,求它包含多少个单词。单词间以一个或者多个空格分开。
第一个单词前,最后一个单词后也可能有0到多个空格。
比如:" abc xyz" 包含两个单词,"ab c xyz " 包含3个单词。

如下的程序解决了这个问题,请填写划线部分缺失的代码。

注意:只填写划线部分的代码,不要填写任何多余的内容。比如已经存在的小括号,注释或说明文字等。

 1 int get_word_num(char* buf)
 2 {
 3 int n = 0; 
 4 int tag = 1; 
 5 char* p = buf;
 6 
 7 for(;*p!=0 && *p!=13 && *p!=10;p++){
 8 if(*p==' ' && tag==0) tag=1;
 9 if( _____________________ ) { n++; tag=0; } //填空
10 }
11 
12 return n;
13 }
14 
15 int main()
16 {
17 char buf[1000];
18 fgets(buf,1000,stdin);
19 
20 printf("%d\n", get_word_num(buf));
21 return 0;
22 }
 1 #include <stdio.h>
 2 int get_word_num(char* buf)
 3 {
 4     int n = 0;   
 5     int tag = 1; 
 6     char* p = buf;
 7     
 8     for(;*p!=0 && *p!=13 && *p!=10;p++){
 9         if(*p==' ' && tag==0) tag=1;
10         if(*p!=' ' &&tag== 1 ) { n++; tag=0; }   //填空
11     }    
12     return n;
13 }
14 int main()
15 {
16     char buf[1000];
17     gets(buf);
18     printf("%d\n", get_word_num(buf));
19     return 0;
20 }

第二题

1/1 + 1/2 + 1/3 + 1/4 + ... 在数学上称为调和级数。

它是发散的,也就是说,只要加上足够多的项,就可以得到任意大的数字。

但是,它发散的很慢:

前1项和达到 1.0
前4项和才超过 2.0
前83项的和才超过 5.0

那么,请你计算一下,要加多少项,才能使得和达到或超过 15.0 呢?

请填写这个整数。

注意:只需要填写一个整数,不要填写任何多余的内容。比如说明文字。

【答案】 1835421

 1 #include <stdio.h>
 2 int main(){
 3     double sum=0;
 4     int i=1;
 5     for(;i<7000000;i++){
 6         sum+=1.0/i;
 7         if(sum>=15){
 8             printf("%d",i);
 9             break;    
10         }        
11     }
12     return 0;
13 }

 

第三题

如果x的x次幂结果为10(参见【图1.png】),你能计算出x的近似值吗?

显然,这个值是介于2和3之间的一个数字。

请把x的值计算到小数后6位(四舍五入),并填写这个小数值。

注意:只填写一个小数,不要写任何多余的符号或说明。

第五届蓝桥杯大赛个人赛(软件类)省赛真题

【答案】 2.506184

#include <stdio.h>
#include<math.h>
#include<stdlib.h>
int main(){
    double x=2.0,b,t=3.0;
    int i=1;
    for(i=1;i<100;i++){
        
        b=(x+t)*1.0/2;
        if(pow(b,b)<10) x=b;
        if(pow(b,b)>10) t=b;
        printf("x=%lf,b=%lf,t=%lf\n",x,b,t);    
    }
    printf("%.6lf\n",x);
    return 0;
}

 

第四题

今有7对数字:两个1,两个2,两个3,...两个7,把它们排成一行。
要求,两个1间有1个其它数字,两个2间有2个其它数字,以此类推,两个7之间有7个其它数字。如下就是一个符合要求的排列:

17126425374635

当然,如果把它倒过来,也是符合要求的。

请你找出另一种符合要求的排列法,并且这个排列法是以74开头的。

注意:只填写这个14位的整数,不能填写任何多余的内容,比如说明注释等。

【答案】 74151643752362

 1 #include <stdio.h>
 2 int x[14]={0};
 3 void dfs(int t){
 4     if(t==4) dfs(t+1);//跳过数字4 ,隐含跳过7    
 5     if(t>6){           //7个数字已经取完 
 6         for(int i=0;i<14;i++)
 7             printf("%d ",x[i]);            
 8     }else
 9     for(int i=2;i<14;i++){
10         if(x[i]==0&&i+t+1<14&&x[i+t+1]==0){//检查是否越界和赋值        
11             x[i]=x[i+t+1]=t;
12             dfs(t+1);
13             x[i]=x[i+t+1]=0;
14         }
15     }
16 }
17 int main(int argc, const char * argv[])
18 {
19     x[0]=x[8]=7;
20     x[1]=x[6]=4;
21     dfs(1);
22     return 0;
23 }

 

第五题

勾股定理,西方称为毕达哥拉斯定理,它所对应的三角形现在称为:直角三角形。

已知直角三角形的斜边是某个整数,并且要求另外两条边也必须是整数。

求满足这个条件的不同直角三角形的个数。

【数据格式】
输入一个整数 n (0<n<10000000) 表示直角三角形斜边的长度。
要求输出一个整数,表示满足条件的直角三角形个数。

例如,输入:
5
程序应该输出:
1

再例如,输入:
100
程序应该输出:
2

再例如,输入:
3
程序应该输出:
0


资源约定:
峰值内存消耗 < 256M
CPU消耗 < 1000ms

#include <stdio.h>
#include <math.h>
int main(){
    long c,sum=0;
    double b,t;
    scanf("%d",&c);
    t=1.0*c/sqrt(2);
    for(int a=1;a<t;a++){
        b=(int)sqrt(c*c-a*a);
        if(a*a+b*b==c*c) sum++;
    }
    printf("%d",sum);
    return 0;
}

 

第六题


你一定听说过“数独”游戏。
如【图1.png】,玩家需要根据9×9盘面上的已知数字,推理出所有剩余空格的数字,并满足每一行、每一列、每一个同色九宫内的数字均含1-9,不重复。

数独的答案都是唯一的,所以,多个解也称为无解。

本图的数字据说是芬兰数学家花了3个月的时间设计出来的较难的题目。但对会使用计算机编程的你来说,恐怕易如反掌了。

本题的要求就是输入数独题目,程序输出数独的唯一解。我们保证所有已知数据的格式都是合法的,并且题目有唯一的解。

格式要求,输入9行,每行9个数字,0代表未知,其它数字为已知。
输出9行,每行9个数字表示数独的解。

例如:
输入(即图中题目):
005300000
800000020
070010500
400005300
010070006
003200080
060500009
004000030
000009700

程序应该输出:
145327698
839654127
672918543
496185372
218473956
753296481
367542819
984761235
521839764

再例如,输入:
800000000
003600000
070090200
050007000
000045700
000100030
001000068
008500010
090000400

程序应该输出:
812753649
943682175
675491283
154237896
369845721
287169534
521974368
438526917
796318452

资源约定:
峰值内存消耗 < 256M
CPU消耗 < 2000ms


请严格按要求输出,不要画蛇添足地打印类似:“请您输入...” 的多余内容。

所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。

注意: main函数需要返回0
注意: 只使用ANSI C/ANSI C++ 标准,不要调用依赖于编译环境或操作系统的特殊函数。
注意: 所有依赖的函数必须明确地在源文件中 #include <xxx>, 不能通过工程设置而省略常用头文件。

提交时,注意选择所期望的编译器类型。

#include<stdio.h>
int a[9][9] ={0};
bool is(int t){
    int x=t/9, y=t%9;
    int down=x/3*3,right=y/3*3;
    //列检查 
    for(int j=0;j<9;j++)
        if(a[j][y]==a[x][y]&&j!=x) return false;
    //行检查 
    for(int j=0;j<9;j++)
        if(a[x][j]==a[x][y]&&j!=y) return false;
    //九宫格检查
    for(int j=right;j<right+3;j++)
        for(int k=down;k<down+3;k++) 
            if(a[k][j]==a[x][y]&&j!=y&&k!=x) return false;
    //通过检测
    return true; 
}
void dfs(int t){
    int x=t/9;
    int y=t%9;
    if(t>=81){
        for(int i=0;i<9;i++){
            for(int j=0;j<9;j++){
                printf("%d",a[i][j]);
            }
            printf("\n");
        }
    }else    
    if(a[x][y]==0){
        for(int i=1;i<=9;i++){
            a[x][y]=i;
            if(is(t)) dfs(t+1);
            a[x][y]=0;
        }    
    }else dfs(t+1);
} 
int main(){
    
    char s[9];
    for(int i=0;i<9;i++){
        gets(s);
        for(int j=0;j<9;j++)
            a[i][j]=s[j]-'0'; 
    }
    dfs(0);
    return 0;
}

 

第七题

G将军有一支训练有素的军队,这个军队除开G将军外,每名士兵都有一个直接上级(可能是其他士兵,也可能是G将军)。现在G将军将接受一个特别的任务,需要派遣一部分士兵(至少一个)组成一个敢死队,为了增加敢死队队员的独立性,要求如果一名士兵在敢死队中,他的直接上级不能在敢死队中。
请问,G将军有多少种派出敢死队的方法。注意,G将军也可以作为一个士兵进入敢死队。
输入格式
输入的第一行包含一个整数n,表示包括G将军在内的军队的人数。军队的士兵从1至n编号,G将军编号为1。
接下来n-1个数,分别表示编号为2, 3, ..., n的士兵的直接上级编号,编号i的士兵的直接上级的编号小于i。
输出格式
输出一个整数,表示派出敢死队的方案数。由于数目可能很大,你只需要输出这个数除10007的余数即可。
样例输入1
3
1 1
样例输出1
4
样例说明
这四种方式分别是:
1. 选1;
2. 选2;
3. 选3;
4. 选2, 3。
样例输入2
7
1 1 2 2 3 3
样例输出2
40

数据规模与约定
对于20%的数据,n ≤ 20;
对于40%的数据,n ≤ 100;
对于100%的数据,1 ≤ n ≤ 100000。

资源约定:
峰值内存消耗 < 256M
CPU消耗 < 2000ms

#include <stdio.h>
int n,a[100001],x[100001];
int sum=0;
bool place(int c,int b){
    if(b==1&&x[a[c]]==1) return false;
    return true;
}
void dfs(int t){
    if(t>n){
        sum++;
    }else{
        for(int i=1;i>=0;i--){            
            if(place(t,i)){
                x[t]=i;
                dfs(t+1);
            }else continue;
        }
    }
}
int main(int argc, const char * argv[])
{
    scanf("%d",&n);
    for(int i=2;i<=n;i++){
        scanf("%d",&a[i]);
    }
    dfs(1);
    sum--;
    printf("%d",sum); 
    return 0;
}