蓝桥杯练习题库-2基础练习题(含参考代码)分析_第1页
蓝桥杯练习题库-2基础练习题(含参考代码)分析_第2页
蓝桥杯练习题库-2基础练习题(含参考代码)分析_第3页
蓝桥杯练习题库-2基础练习题(含参考代码)分析_第4页
蓝桥杯练习题库-2基础练习题(含参考代码)分析_第5页
已阅读5页,还剩23页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

精选优质文档-----倾情为你奉上精选优质文档-----倾情为你奉上专心---专注---专业专心---专注---专业精选优质文档-----倾情为你奉上专心---专注---专业基础练习数列排序

时间限制:1.0s

内存限制:512.0MB问题描述给定一个长度为n的数列,将这个数列按从小到大的顺序排列。1<=n<=200输入格式第一行为一个整数n。

第二行包含n个整数,为待排序的数,每个整数的绝对值小于10000。输出格式输出一行,按从小到大的顺序输出排序后的数列。样例输入5

83649样例输出34689锦囊1使用排序算法。锦囊2可以使用冒泡排序、排入排序等,也可以使用快速排序等更快的,还可以直接调用系统的函数。#include<stdio.h>#include<stdlib.h>voidPrint(int*data,intn){ inti; for(i=0;i<n;i++) { printf("%d",data[i]); } printf("\n");}intSplit(int*data,intpre,intrear){ intvalue=data[pre]; while(pre<rear) { while(data[rear]>=value&&pre<rear)rear--; data[pre]=data[rear]; while(data[pre]<value&&pre<rear)pre++; data[rear]=data[pre]; } data[pre]=value; returnpre;}//快速排序voidQuickSort(int*data,intpre,intrear){ if(pre<rear) { intmid=Split(data,pre,rear); QuickSort(data,pre,mid-1); QuickSort(data,mid+1,rear); }}intmain(){ inti; intn; int*data; scanf("%d",&n); data=(int*)malloc(sizeof(int)*n); for(i=0;i<n;i++) { scanf("%d",&data[i]); } QuickSort(data,0,n-1); Print(data,n); return0;}

基础练习十六进制转八进制

时间限制:1.0s

内存限制:512.0MB问题描述给定n个十六进制正整数,输出它们对应的八进制数。输入格式输入的第一行为一个正整数n(1<=n<=10)。

接下来n行,每行一个由0~9、大写字母A~F组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过。输出格式输出n行,每行为输入对应的八进制正整数。注意输入的十六进制数不会有前导0,比如012A。

输出的八进制数也不能有前导0。样例输入2

39

123ABC样例输出71

提示先将十六进制数转换成某进制数,再由某进制数转换成八进制。锦囊1使用二进制。锦囊2先把十六进制转成二进制,每位十六进制正好转成4位二进制,然后再将二进制转成八进制,每三个二进制转成一个八进制。#include<stdio.h>#include<stdlib.h>#include<string.h>#defineMaxSizevoidsaveB(char*b,charc3,charc2,charc1,charc0,intstart){ b[start]=c3; b[start+1]=c2; b[start+2]=c1; b[start+3]=c0;}inthtob(char*h,char*b){ inti,j; inthl=strlen(h); for(i=0;i<hl;i++) switch(h[i]) { case'0': { saveB(b,'0','0','0','0',4*i); break; } case'1': { saveB(b,'0','0','0','1',4*i); break; } case'2': { saveB(b,'0','0','1','0',4*i); break; } case'3': { saveB(b,'0','0','1','1',4*i); break; } case'4': { saveB(b,'0','1','0','0',4*i); break; } case'5': { saveB(b,'0','1','0','1',4*i); break; } case'6': { saveB(b,'0','1','1','0',4*i); break; } case'7': { saveB(b,'0','1','1','1',4*i); break; } case'8': { saveB(b,'1','0','0','0',4*i); break; } case'9': { saveB(b,'1','0','0','1',4*i); break; } case'A': { saveB(b,'1','0','1','0',4*i); break; } case'B': { saveB(b,'1','0','1','1',4*i); break; } case'C': { saveB(b,'1','1','0','0',4*i); break; } case'D': { saveB(b,'1','1','0','1',4*i); break; } case'E': { saveB(b,'1','1','1','0',4*i); break; } case'F': { saveB(b,'1','1','1','1',4*i); break; } } return4*hl;}intbtoo(char*b,char*o,intbl){ inti,j; intol; intvalue; if(bl%3==0) ol=bl/3; else ol=bl/3+1; j=bl-1; for(i=ol-1;i>=0;i--) { if(i>0) o[i]=b[j]-48+(b[j-1]-48)*2+(b[j-2]-48)*4+48; else { switch(j) { case2: o[i]=b[j]-48+(b[j-1]-48)*2+(b[j-2]-48)*4+48; break; case1: o[i]=b[j]-48+(b[j-1]-48)*2+48; break; case0: o[i]=b[j]; break; } } j=j-3; } returnol;}voidprintO(char*o,intol){ inti=0; if(o[0]=='0') i=1; for(;i<ol;i++) { printf("%c",o[i]); } printf("\n");}main(){ charh[MaxSize]; charb[4*MaxSize]; charo[4*MaxSize/3+1]; intn,i,bl,ol; scanf("%d",&n); getchar(); for(i=0;i<n;i++) { gets(h); bl=htob(h,b); ol=btoo(b,o,bl); printO(o,ol); }}

基础练习十六进制转十进制

时间限制:1.0s

内存限制:512.0MB问题描述从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出。

注:十六进制数中的10~15分别用大写的英文字母A、B、C、D、E、F表示。样例输入FFFF样例输出65535锦囊1按16进制展开。锦囊2按数位依次操作,每次将前面的乘16,再加上当前数位的值。本题的C参考代码如下:#include<stdio.h>#include<string.h>#include<math.h>intmain(){doublesum=0,x;chara[8];intlen,i=0;gets(a);len=strlen(a);while(len){if(a[len-1]>='A'&&a[len-1]<='F')x=(a[len-1]-'7')*pow(16,i++);else x=(a[len-1]-'0')*pow(16,i++);sum+=x;len--;}printf("%.0lf",sum);return0;}

基础练习十进制转十六进制

时间限制:1.0s

内存限制:512.0MB问题描述十六进制数是在程序设计时经常要使用到的一种整数的表示方式。它有0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F共16个符号,分别表示十进制数的0至15。十六进制的计数方法是满16进1,所以十进制数16在十六进制中是10,而十进制的17在十六进制中是11,以此类推,十进制的30在十六进制中是1E。

给出一个非负整数,将它表示成十六进制的形式。输入格式输入包含一个非负整数a,表示要转换的数。0<=a<=输出格式输出这个整数的16进制表示样例输入30样例输出1E锦囊1按除16取余倒数(也可使用格式输出)。锦囊2可以使用递归来处理,递归参数为要转换的数字,如果该数字大于等于16,则将递归处理该数整除16的值,然后再输出最后一位。C/C++语言可以使用格式输出直接输出转换后的结果。本题的C参考代码如下:#include<stdio.h>#include<stdlib.h>chardata[]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};//输出voidPrint(char*num,intn){ inti; for(i=n-1;i>=0;i--)printf("%c",num[i]); printf("\0"); printf("\n");}//将十六进制数转换为十进制数intTransform(char*num,longlongvalue){ intn=0; while(value>=16) { num[n++]=data[value%16]; value/=16; } num[n++]=data[value%16]; returnn;}intmain(){ longlongvalue; charnum[10]; intn; scanf("%I64d",&value); n=Transform(num,value); Print(num,n); return0;}

基础练习特殊回文数

时间限制:1.0s

内存限制:512.0MB问题描述是一个非常特殊的数,它从左边读和从右边读是一样的。

输入一个正整数n,编程求所有这样的五位和六位十进制数,满足各位数字之和等于n。输入格式输入一行,包含一个正整数n。输出格式按从小到大的顺序输出满足条件的整数,每个整数占一行。样例输入52样例输出

数据规模和约定1<=n<=54。锦囊1枚举加判断。锦囊2枚举所有的五位和六位整数,先判断它们是否为回文数,然后再计算所有数字和,判断是否为n。本题的C参考代码如下:#include<stdio.h>intmain(){ inta,b,c,d,e,f,t,all; scanf("%d",&t); for(a=1;a<10;a++) for(b=0;b<10;b++) for(c=0;c<10;c++) for(d=0;d<10;d++) for(e=0;e<10;e++) { if(a==e) if(b==d) { all=a+b+c+d+e; if(all==t) printf("%d\n",a*10000+b*1000+c*100+d*10+e); } } for(a=1;a<10;a++) for(b=0;b<10;b++) for(c=0;c<10;c++) for(d=0;d<10;d++) for(e=0;e<10;e++) for(f=0;f<10;f++) { if(a==f) if(b==e) if(c==d) { all=a+b+c+d+e+f; if(all==t) printf("%d\n",a*+b*10000+c*1000+d*100+e*10+f); } } return0;}

基础练习回文数

时间限制:1.0s

内存限制:512.0MB问题描述1221是一个非常特殊的数,它从左边读和从右边读是一样的,编程求所有这样的四位十进制数。输出格式按从小到大的顺序输出满足条件的四位十进制数。锦囊1枚举加判断。锦囊2枚举所有的四位整数,将它们的三位分别分离出来,然后判断是否第一位与第四位相同且第二位和第三位相同。本题的C参考代码如下:#include<stdio.h>intmain(){inta,b,c,d,i;for(i=1000;i<=9999;i++){a=i/1000;b=i/100%10;c=i/10%10;d=i%10;if(a==d&&b==c)printf("%d\n",i);}return0;}

基础练习特殊的数字

时间限制:1.0s

内存限制:512.0MB问题描述153是一个非常特殊的数,它等于它的每位数字的立方和,即153=1*1*1+5*5*5+3*3*3。编程求所有满足这种条件的三位十进制数。输出格式按从小到大的顺序输出满足条件的三位十进制数,每个数占一行。#include<stdio.h>intmain(){inti,j,k,n;for(n=100;n<1000;n++){i=n/100;j=n/10%10;k=n%10;if(i*100+j*10+k==i*i*i+j*j*j+k*k*k)printf("%d\n",n);}return0;}

基础练习杨辉三角形

时间限制:1.0s

内存限制:256.0MB问题描述杨辉三角形又称Pascal三角形,它的第i+1行是(a+b)i的展开式的系数。它的一个重要性质是:三角形中的每个数字等于它两肩上的数字相加。下面给出了杨辉三角形的前4行:

1

11

1211331给出n,输出它的前n行。输入格式输入包含一个数n。输出格式输出杨辉三角形的前n行。每一行从这一行的第一个数开始依次输出,中间使用一个空格分隔。请不要在前面输出多余的空格。样例输入4样例输出1

11

121

1331数据规模与约定1<=n<=34。锦囊1使用二维数组。锦囊2使用一个二维数组来保存杨辉三角形,先将三角形计算出来,然后再输出。本题的C参考代码如下:#include<stdio.h>#defineMAXN40intn;inta[MAXN][MAXN];intmain(){inti,j;scanf("%d",&n);a[0][0]=1;for(i=0;i<n;++i){a[i][0]=a[i][i]=1;for(j=1;j<i;++j)a[i][j]=a[i-1][j-1]+a[i-1][j];}for(i=0;i<n;++i){for(j=0;j<=i;++j)printf("%d",a[i][j]);printf("\n");}return0;}

基础练习查找整数

时间限制:1.0s

内存限制:256.0MB问题描述给出一个包含n个整数的数列,问整数a在数列中的第一次出现是第几个。输入格式第一行包含一个整数n。第二行包含n个非负整数,为给定的数列,数列中的每个数都不大于10000。第三行包含一个整数a,为待查找的数。输出格式如果a在数列中出现了,输出它第一次出现的位置(位置从1开始编号),否则输出-1。样例输入6

194839

9样例输出2数据规模与约定1<=n<=1000。锦囊1使用循环语句、判断语句和跳出循环语句。锦囊2将所有数读入到一个数组中,然后使用循环语句依次枚举数组中的每个元素,每次和要查找的元素比较,若找到则记录并跳出循环。本题的C参考代码如下:#include<stdio.h>#defineMAXN10001intn,a,ans;ints[MAXN];intmain(){inti;scanf("%d",&n);for(i=0;i<n;++i)scanf("%d",&s[i]);scanf("%d",&a);ans=-1;for(i=0;i<n;++i){if(s[i]==a){ans=i+1;break;}}printf("%d",ans);return0;}

基础练习数列特征

时间限制:1.0s

内存限制:256.0MB问题描述给出n个数,找出这n个数的最大值,最小值,和。输入格式第一行为整数n,表示数的个数。第二行有n个数,为给定的n个数,每个数的绝对值都小于10000。输出格式输出三行,每行一个整数。第一行表示这些数中的最大值,第二行表示这些数中的最小值,第三行表示这些数的和。样例输入5

13-245样例输出5

-2

3数据规模与约定1<=n<=10000。锦囊1使用循环语句和标志变量。锦囊2将所有数读入到一个数组中,然后使用循环语句依次枚举数组中的每个元素,使用三个变量分别表示当前找到的最大值、最小值及前一部分数的和。最后输出。#include<stdio.h>#include<stdlib.h>#defineMAXSIZE10000intmain(){ inti; intn; intvalue; intmax=-MAXSIZE; intmin=MAXSIZE; intsum=0; scanf("%d",&n); for(i=0;i<n;i++) { scanf("%d",&value); if(value>max)max=value; if(value<min)min=value; sum+=value; } printf("%d\n",max); printf("%d\n",min); printf("%d\n",sum); return0;}

基础练习字母图形

时间限制:1.0s

内存限制:256.0MB问题描述利用字母可以组成一些美丽的图形,下面给出了一个例子:ABCDEFGBABCDEFCBABCDEDCBABCDEDCBABC这是一个5行7列的图形,请找出这个图形的规律,并输出一个n行m列的图形。输入格式输入一行,包含两个整数n和m,分别表示你要输出的图形的行数的列数。输出格式输出n行,每个m个字符,为你的图形。样例输入57样例输出ABCDEFG

BABCDEF

CBABCDE

DCBABCD

EDCBABC数据规模与约定1<=n,m<=26。锦囊1字母的序号与两个坐标的差的绝对值有关。锦囊2用两重循环来枚举所有的坐标,使用绝对值函数计算出坐标的差,再输出对应的字符。#include<stdio.h>#include<stdlib.h>#defineMAXSIZE26//输出voidPrint(charmatrix[MAXSIZE][MAXSIZE],intn,intm){ inti,j; for(i=0;i<n;i++) { for(j=0;j<m;j++) { printf("%c",matrix[i][j]); } printf("\n"); }}//实现字母图形voidDrawing(intn,intm){ inti,j; intpoint=0; charstr; charmatrix[MAXSIZE][MAXSIZE]; for(i=0;i<n;i++) { str='A'; for(j=i;j<m;j++) { matrix[i][j]=str++; } str='A'; for(j=i-1;j>=0;j--) { matrix[i][j]=++str; } } Print(matrix,n,m);}intmain(){ intn,m; scanf("%d%d",&n,&m); Drawing(n,m); return0;

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论