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)小朋友排队
代码超时了。。。。。。。。。