蓝桥杯
蓝桥杯
_ dingding_
华南理工大学硕士生,主要关注推荐系统,机器学习等。
展开
-
蓝桥杯小结
我不是大牛,代码能力也不强,但好歹也坚持了这么久,在此记录一下我奋斗的时光~ 从前年开始我们学校就有蓝桥杯的校内预选赛,然后我并没通过,真丢人。。。去年得知比赛又来了,于是厚着脸皮来参加(因为他们都是大二的童鞋~)总算是通过了。寒假前把蓝桥杯练习系统上会写的题都写了,也是费了好一番功夫。接着寒假没敲代码。这个学期开学回来后,得知比赛还有两月,于是又把我的代码捡起来了。学习算法的过程真的是很崩原创 2017-04-09 20:19:39 · 831 阅读 · 0 评论 -
四平方和
四平方和定理,又称为拉格朗日定理: 每个正整数都可以表示为至多4个正整数的平方和。 如果把0包括进去,就正好可以表示为4个数的平方和。比如: 5 = 0^2 + 0^2 + 1^2 + 2^2 7 = 1^2 + 1^2 + 1^2 + 2^2 (^符号表示乘方的意思)对于一个给定的正整数,可能存在多种平方和的表示法。 要求你对4个数排序: 0 <= a <= b <= c <= d原创 2017-03-22 17:44:55 · 1990 阅读 · 1 评论 -
煤球数目
有一堆煤球,堆成三角棱锥形。具体: 第一层放1个, 第二层3个(排列成三角形), 第三层6个(排列成三角形), 第四层10个(排列成三角形), …. 如果一共有100层,共有多少个煤球?代码:#include<iostream>using namespace std;int main(){ int sum=0,total=0; for(int i=1;i<=100;原创 2017-03-25 13:07:14 · 763 阅读 · 0 评论 -
生日蜡烛
某君从某年开始每年都举办一次生日party,并且每次都要吹熄与年龄相同根数的蜡烛。现在算起来,他一共吹熄了236根蜡烛。请问,他从多少岁开始过生日party的?请填写他开始过生日party的年龄数。 注意:你提交的应该是一个整数,不要填写任何多余的内容或说明性文字。代码:#include<iostream>using namespace std;int main(){ for(int原创 2017-03-25 13:16:16 · 359 阅读 · 0 评论 -
切面条
一根高筋拉面,中间切一刀,可以得到2根面条。如果先对折1次,中间切一刀,可以得到3根面条。如果连续对折2次,中间切一刀,可以得到5根面条。那么,连续对折10次,中间切一刀,会得到多少面条呢?答案是个整数,请通过浏览器提交答案。不要填写任何多余的内容。思路:公式2^n+1; 代码:#include<iostream>#include<math.h>using namespace std;int原创 2017-03-27 19:58:24 · 750 阅读 · 0 评论 -
凑算式
这个算式中A~I代表1~9的数字,不同的字母代表不同的数字。比如: 6+8/3+952/714 就是一种解法, 5+3/1+972/486 是另一种解法。这个算式一共有多少种解法?注意:你提交应该是个整数,不要填写任何多余的内容或说明性文字。这里注意除法的问题,很容易出现精度的问题,最好先把式子化简一下,变成乘法,这样会省很多事哦~代码一:直接用9重for暴力求解#include<iostrea原创 2017-03-25 13:57:53 · 914 阅读 · 0 评论 -
快速排序
排序在各种场合经常被用到。 快速排序是十分常用的高效率的算法。其思想是:先选一个“标尺”, 用它把整个队列过一遍筛子, 以保证:其左边的元素都不大于它,其右边的元素都不小于它。这样,排序问题就被分割为两个子区间。 再分别对子区间排序就可以了。下面的代码是一种实现,请分析并填写划线部分缺少的代码。#include <stdio.h>void swap(int a[], int i, int j原创 2017-03-25 14:20:32 · 288 阅读 · 0 评论 -
奖券数目
奖券数目有些人很迷信数字,比如带“4”的数字,认为和“死”谐音,就觉得不吉利。虽然这些说法纯属无稽之谈,但有时还要迎合大众的需求。某抽奖活动的奖券号码是5位数(10000-99999),要求其中不要出现带“4”的号码,主办单位请你计算一下,如果任何两张奖券不重号,最多可发出奖券多少张。请提交该数字(一个整数),不要写任何多余的内容或说明性文字。#includeusing name原创 2017-03-12 22:01:39 · 333 阅读 · 0 评论 -
格子中输出
格子中输出StringInGrid函数会在一个指定大小的格子中打印指定的字符串。要求字符串在水平、垂直两个方向上都居中。如果字符串太长,就截断。如果不能恰好居中,可以稍稍偏左或者偏上一点。下面的程序实现这个逻辑,请填写划线部分缺少的代码。#include #include void StringInGrid(int width, int height, const原创 2017-03-07 21:31:45 · 545 阅读 · 0 评论 -
交换瓶子
有N个瓶子,编号 1 ~ N,放在架子上。 比如有5个瓶子: 2 1 3 5 4 要求每次拿起2个瓶子,交换它们的位置。 经过若干次后,使得瓶子的序号为: 1 2 3 4 5对于这么简单的情况,显然,至少需要交换2次就可以复位。如果瓶子更多呢?你可以通过编程来解决。输入格式为两行: 第一行: 一个正整数N(N<10000), 表示瓶子的数目 第二行:N个正整数,用空格分开,表示原创 2017-03-22 17:34:58 · 374 阅读 · 0 评论 -
抽签
X星球要派出一个5人组成的观察团前往W星。 其中: A国最多可以派出4人。 B国最多可以派出2人。 C国最多可以派出2人。 ….那么最终派往W星的观察团会有多少种国别的不同组合呢?下面的程序解决了这个问题。 数组a[] 中既是每个国家可以派出的最多的名额。 程序执行结果为: DEFFF CEFFF CDFFF CDEFF CCFFF CCEFF CCDFF CCDEF原创 2017-03-25 14:43:21 · 2161 阅读 · 0 评论 -
九数组分数
1,2,3…9 这九个数字组成一个分数,其值恰好为1/3,如何组法?下面的程序实现了该功能,请填写划线部分缺失的代码。#include <stdio.h>void test(int x[]){ int a = x[0]*1000 + x[1]*100 + x[2]*10 + x[3]; int b = x[4]*10000 + x[5]*1000 + x[6]*100 + x[7]原创 2017-03-25 16:29:14 · 1113 阅读 · 0 评论 -
方格填数
如下的10个格子(如果显示有问题,也可以参看【图1.jpg】)填入0~9的数字。要求:连续的两个数字不能相邻。 (左右、上下、对角都算相邻)一共有多少种可能的填数方案?请填写表示方案数目的整数。 注意:你提交的应该是一个整数,不要填写任何多余的内容或说明性文字。 这里代码虽然看上去很复杂,却写的比较简单直白,很容易看懂,这就是最原始的深度优先遍历~代码:#include<iostream>#原创 2017-03-20 21:19:28 · 1022 阅读 · 0 评论 -
六角填数
如图所示六角形中,填入1~12的数字。使得每条直线上的数字之和都相同。图中,已经替你填好了3个数字,请你计算星号位置所代表的数字是多少?请通过浏览器提交答案,不要填写多余的内容。 代码: 刚开始没有进行改进时的代码#include<iostream>using namespace std;int a[13];int visit[13];void dfs(int index){原创 2017-03-20 21:28:01 · 1217 阅读 · 1 评论 -
三羊献瑞
三羊献瑞观察下面的加法算式: 祥 瑞 生 辉 + 三 羊 献 瑞------------------- 三 羊 生 瑞 气(如果有对齐问题,可以参看【图1.jpg】)其中,相同的汉字代表相同的数字,不同的汉字代表不同的数字。请你填写“三羊献瑞”所代表的4位数字(答案唯一),不要填写任何多余内容。 #includeusing namesp原创 2017-03-07 21:10:14 · 449 阅读 · 0 评论 -
牌型种数
牌型种数小明被劫持到X赌城,被迫与其他3人玩牌。一副扑克牌(去掉大小王牌,共52张),均匀发给4个人,每个人13张。这时,小明脑子里突然冒出一个问题:如果不考虑花色,只考虑点数,也不考虑自己得到的牌的先后顺序,自己手里能拿到的初始牌型组合一共有多少种呢?请填写该整数,不要填写任何多余的内容或说明文字。#includeusing namespace std;int ans原创 2017-03-12 22:07:14 · 1292 阅读 · 0 评论 -
移动距离
移动距离X星球居民小区的楼房全是一样的,并且按矩阵样式排列。其楼房的编号为1,2,3...当排满一行时,从下一行相邻的楼往反方向排号。比如:当小区排号宽度为6时,开始情形如下:1 2 3 4 5 612 11 10 9 8 713 14 15 .....我们的问题是:已知了两个楼号m和n,需要求出它们之间的最短移动距离(不能斜线方向移动)输入为3个整数原创 2017-03-12 22:12:23 · 394 阅读 · 0 评论 -
生成1~n的全排列
代码: 这个递归太牛#include<iostream>using namespace std;void f(int n,int A[],int cur){ if(cur==n)//递归边界 ,A数组里面装满元素则输出 { for(int i=0;i<n;i++) { cout<<A[i]<<" ";原创 2017-03-19 16:50:36 · 17810 阅读 · 2 评论 -
未名湖边的烦恼
问题描述 每年冬天,北大未名湖上都是滑冰的好地方。北大体育组准备了许多冰鞋,可是人太多了,每天下午收工后,常常一双冰鞋都不剩。 每天早上,租鞋窗口都会排起长龙,假设有还鞋的m个,有需要租鞋的n个。现在的问题是,这些人有多少种排法,可以避免出现体育组没有冰鞋可租的尴尬场面。(两个同样需求的人(比如都是租鞋或都是还鞋)交换位置是同一种排法)输入格式 两个整数,表示m和n输出格式 一个整数,原创 2017-03-22 14:49:04 · 416 阅读 · 0 评论 -
李白打酒
话说大诗人李白,一生好饮。幸好他从不开车。 一天,他提着酒壶,从家里出来,酒壶中有酒2斗。他边走边唱: 无事街上走,提壶去打酒。 逢店加一倍,遇花喝一斗。 这一路上,他一共遇到店5次,遇到花10次,已知最后一次遇到的是花,他正好把酒喝光了。 请你计算李白遇到店和花的次序,可以把遇店记为a,遇花记为b。则:babaabbabbabbbb 就是合理的次序。像这样的答案一共有多少呢?请你计算出原创 2017-03-22 14:52:24 · 677 阅读 · 0 评论 -
购物单(excel做法)
小明刚刚找到工作,老板人很好,只是老板夫人很爱购物。老板忙的时候经常让小明帮忙到商场代为购物。小明很厌烦,但又不好推辞。这不,XX大促销又来了!老板夫人开出了长长的购物单,都是有打折优惠的。 小明也有个怪癖,不到万不得已,从不刷卡,直接现金搞定。 现在小明很心烦,请你帮他计算一下,需要从取款机上取多少现金,才能搞定这次购物。取款机只能提供100元面额的纸币。小明想尽可能少取些现金,够用就行了。原创 2017-04-09 19:45:01 · 4915 阅读 · 4 评论 -
三部排序
标题:三部排序 一般的排序有许多经典算法,如快速排序、希尔排序等。 但实际应用时,经常会或多或少有一些特殊的要求。我们没必要套用那些经典算法,可以根据实际情况建立更好的解法。 比如,对一个整型数组中的数字进行分类排序: 使得负数都靠左端,正数都靠右端,0在中部。注意问题的特点是:负数区域和正数区域内并不要求有序。可以利用这个特点通过1次线性扫描就结束战斗!!原创 2017-04-05 16:09:15 · 468 阅读 · 0 评论 -
高斯日记
大数学家高斯有个好习惯:无论如何都要记日记。他的日记有个与众不同的地方,他从不注明年月日,而是用一个整数代替,比如:4210后来人们知道,那个整数就是日期,它表示那一天是高斯出生后的第几天。这或许也是个好习惯,它时时刻刻提醒着主人:日子又过去一天,还有多少时光可以用于浪费呢?高斯出生于:1777年4月30日。在高斯发现的一个重要定理的日记上标注着:5343,因此可算出那天是:1791年12月15日。原创 2017-04-05 20:22:24 · 534 阅读 · 0 评论 -
Anagrams问题
问题描述 Anagrams指的是具有如下特性的两个单词:在这两个单词当中,每一个英文字母(不区分大小写)所出现的次数都是相同的。例如,“Unclear”和“Nuclear”、“Rimon”和“MinOR”都是Anagrams。编写一个程序,输入两个单词,然后判断一下,这两个单词是否是Anagrams。每一个单词的长度不会超过80个字符,而且是大小写无关的。 输入格式:输入有两行,分别为两原创 2017-04-06 09:06:16 · 848 阅读 · 0 评论 -
算法训练 前缀表达式
问题描述 编写一个程序,以字符串方式输入一个前缀表达式,然后计算它的值。输入格式为:“运算符 对象1 对象2”,其中,运算符为“+”(加法)、“-”(减法)、“*”(乘法)或“/”(除法),运算对象为不超过10的整数,它们之间用一个空格隔开。要求:对于加、减、乘、除这四种运算,分别设计相应的函数来实现。 输入格式:输入只有一行,即一个前缀表达式字符串。 输出格式:输出相应的计算结果原创 2017-04-06 09:40:27 · 327 阅读 · 0 评论 -
第四届蓝桥杯C/C++ B组
这里写我会写的~ 第一题:高斯日记 4’ 第二题:马虎的算式 5’ 第三题:第39级台阶 8’ 第四题:黄金连分数 12’ 第五题:前缀判断 5’ 第六题:三部排序 7’ 第七题:错误票据 4’ 第八题:翻硬币 10’ 第九题:带分数 16’ 第十题:连号区间数 29’原创 2017-04-06 19:45:51 · 470 阅读 · 0 评论 -
第六届蓝桥杯C/C++ B组
这里写我会写的~ 第一题:奖券数目 第二题:星系炸弹(其实可以手算~2017年8月5日) 第三题:三羊献瑞 第四题:格子中输出 第五题:九数组分数 第六题:加法变乘法 第七题:牌型种数 第八题:移动距离 第九题:垒骰子 第十题:生命之树原创 2017-03-25 17:19:47 · 527 阅读 · 0 评论 -
第七届蓝桥杯C/C++ B组
这里写我会写的~ 第一题:煤球数目 第二题:生日蜡烛 第三题:凑算式 第四题:快速排序 第五题:抽签 第六题:方格填数 第七题:剪邮票(不会判断是否联通) 第八题:四平方和 第九题:交换瓶子 第十题:最大比例(看不懂!)原创 2017-03-25 15:48:55 · 477 阅读 · 0 评论 -
啤酒和饮料
啤酒每罐2.3元,饮料每罐1.9元。小明买了若干啤酒和饮料,一共花了82.3元。我们还知道他买的啤酒比饮料的数量少,请你计算他买了几罐啤酒。注意:答案是一个整数。请通过浏览器提交答案。不要书写任何多余的内容(例如:写了饮料的数量,添加说明文字等)。 代码:#include<iostream>using namespace std;int main(){ int x,y; fo原创 2017-04-06 20:10:32 · 457 阅读 · 0 评论 -
第五届蓝桥杯C/C++ B组
这里写我会写的~ 第一题:啤酒和饮料 4’ 第二题:切面条 5’ 第三题:李白打酒 8’ 第四题:史丰收速算 7’ 第五题:打印图形 12’ 第六题:奇怪的分式 11’ 第七题:六角填数 12’ 第八题:蚂蚁感冒 10’ 第九题:地宫取宝 12’ 第十题:小朋友排队 19’原创 2017-04-06 20:21:41 · 393 阅读 · 0 评论 -
振兴中华
小明参加了学校的趣味运动会,其中的一个项目是:跳格子。 地上画着一些格子,每个格子里写一个字,如下所示:(也可参见p1.jpg)从我做起振 我做起振兴 做起振兴中 起振兴中华比赛时,先站在左上角的写着“从”字的格子里,可以横向或纵向跳到相邻的格子里,但不能跳到对角的格子或其它位置。一直要跳到“华”字结束。要求跳过的路线刚好构成“从我做起振兴中华”这句话。请你帮助小明算一算他一共有多少种可能的原创 2017-04-05 19:19:54 · 348 阅读 · 0 评论 -
第39级台阶 蓝桥杯
小明刚刚看完电影《第39级台阶》,离开电影院的时候,他数了数礼堂前的台阶数,恰好是39级! 站在台阶前,他突然又想着一个问题: 如果我每一步只能迈上1个或2个台阶。先迈左脚,然后左右交替,最后一步是迈右脚,也就是说一共要走偶数步。那么,上完39级台阶,有多少种不同的上法呢?请你利用计算机的优势,帮助小明寻找答案。要求提交的是一个整数。 注意:不要提交解答过程,或其它的辅助说明文字。思路:用d原创 2017-04-05 19:05:41 · 1069 阅读 · 0 评论 -
k倍区间
给定一个长度为N的数列,A1, A2, … AN,如果其中一段连续的子序列Ai, Ai+1, … Aj(i <= j)之和是K的倍数,我们就称这个区间[i, j]是K倍区间。 你能求出数列中总共有多少个K倍区间吗? 输入第一行包含两个整数N和K。(1 <= N, K <= 100000) 以下N行每行包含一个整数Ai。(1 <= Ai <= 100000) 输出输出一个整数,代表K倍区间的数原创 2017-04-09 18:57:59 · 685 阅读 · 2 评论 -
打印图形
小明在X星球的城堡中发现了如下图形和文字: 小明开动脑筋,编写了如下的程序,实现该图形的打印。#define N 70void f(char a[][N], int rank, int row, int col){ if(rank==1){ a[row][col] = '*'; return; } int w = 1; int i原创 2017-03-27 19:50:30 · 474 阅读 · 0 评论 -
连号区间数
标题:连号区间数小明这些天一直在思考这样一个奇怪而有趣的问题:在1~N的某个全排列中有多少个连号区间呢?这里所说的连号区间的定义是:如果区间[L, R] 里的所有元素(即此排列的第L个到第R个元素)递增排序后能得到一个长度为R-L+1的“连续”数列,则称这个区间连号区间。当N很小的时候,小明可以很快地算出答案,但是当N变大的时候,问题就不是那么简单了,现在小明需要你的帮助。输入格式: 第一行是一原创 2017-04-05 15:33:32 · 931 阅读 · 0 评论 -
翻硬币
题目标题:翻硬币小明正在玩一个“翻硬币”的游戏。桌上放着排成一排的若干硬币。我们用 * 表示正面,用 o 表示反面(是小写字母,不是零)。比如,可能情形是:**oo***oooo如果同时翻转左边的两个硬币,则变为:oooo***oooo现在小明的问题是:如果已知了初始状态和要达到的目标状态,每次只能同时翻转相邻的两个硬币,那么对特定的局面,最少要翻动多少次呢?我们约定:把翻动相邻的两个硬币叫做一步原创 2017-04-05 16:06:31 · 323 阅读 · 0 评论 -
马虎的算式
标题: 马虎的算式小明是个急性子,上小学的时候经常把老师写在黑板上的题目抄错了。 有一次,老师出的题目是:36 x 495 = ? 他却给抄成了:396 x 45 = ? 但结果却很戏剧性,他的答案竟然是对的!! 因为 36 * 495 = 396 * 45 = 17820 类似这样的巧合情况可能还有很多,比如:27 * 594 = 297 * 54原创 2017-04-05 16:12:33 · 373 阅读 · 0 评论 -
算法训练 Torry的困惑(基本型)
问题描述 Torry从小喜爱数学。一天,老师告诉他,像2、3、5、7……这样的数叫做质数。Torry突然想到一个问题,前10、100、1000、10000……个质数的乘积是多少呢?他把这个问题告诉老师。老师愣住了,一时回答不出来。于是Torry求助于会编程的你,请你算出前n个质数的乘积。不过,考虑到你才接触编程不久,Torry只要你算出这个数模上50000的值。 输入格式 仅包含一个正原创 2017-04-05 16:25:26 · 742 阅读 · 0 评论 -
算法训练 字串统计
问题描述 给定一个长度为n的字符串S,还有一个数字L,统计长度大于等于L的出现次数最多的子串(不同的出现可以相交),如果有多个,输出最长的,如果仍然有多个,输出第一次出现最早的。输入格式 第一行一个数字L。 第二行是字符串S。 L大于0,且不超过S的长度。输出格式 一行,题目要求的字符串。 输入样例1: 4 bbaabbaaaaa 输出样例1: bba原创 2017-04-05 16:31:06 · 387 阅读 · 0 评论 -
错误票据
某涉密单位下发了某种票据,并要在年终全部收回。每张票据有唯一的ID号。全年所有票据的ID号是连续的,但ID的开始数码是随机选定的。因为工作人员疏忽,在录入ID号的时候发生了一处错误,造成了某个ID断号,另外一个ID重号。你的任务是通过编程,找出断号的ID和重号的ID。假设断号不可能发生在最大和最小号。要求程序首先输入一个整数N(N<100)表示后面数据行数。 接着读入N行数据。 每行数据长度不等原创 2017-04-05 17:29:35 · 360 阅读 · 0 评论