蓝桥杯复习线 day2

2018年省赛C++A组:
五.画图+递归
思路:找到递归三要素:
1.递归函数的作用:函数:void draw(char* buf, int w, int x, int y, int size),画出以第Y+1行的第X个为中心的size*size大小的图;
2.递归结束条件:size=1,即只画一个;
3.如何缩小参数范围:即把size变成1,可以从“如何把第二个拆分成第一个入手”;

代码:

#include <stdio.h>
#include <stdlib.h>
void show(char* buf, int w){
     int i,j;
     for(i=0; i<w; i++){
         for(j=0; j<w; j++){
             printf("%c", buf[i*w+j]==0? ' ' : 'o');
         }
         printf("\n");
     }
}
void draw(char* buf, int w, int x, int y, int size){
     if(size==1){
         buf[y*w+x] = 1;
         return;
     }
     
     int n = size / 3 ; //填空
     draw(buf, w, x, y, n);
     draw(buf, w, x-n, y ,n);
     draw(buf, w, x+n, y ,n);
     draw(buf, w, x, y-n ,n);
     draw(buf, w, x, y+n ,n);
}
int main()
{
     int N = 3;
     int t = 1;
     int i;
     for(i=0; i<N; i++) t *= 3;
     
     char* buf = (char*)malloc(t*t);
     for(i=0; i<t*t; i++) buf[i] = 0;
     
     draw(buf, t, t/2, t/2, t);
     show(buf, t);
     free(buf);
     
     return 0;
}

六.字符串的读取+时间题
题目:
在这里插入图片描述
在这里插入图片描述
思路:
1.字符串相关:
1).如何读取字符串:利用getline函数:cin.getline(line, 100);
前一个参数是输入的字符串(要在前面定义char line[100];),后一个是输入字符串的最大长度;
2).如何得到字符串中的数据:利用sscanf:sscanf(line, "%d:%d:%d %d:%d:%d", &h1, &m1, &s1, &h2, &m2, &s2);

2.遇到时:分:秒的题,可以转换成秒数计算;

3.时钟前补零成两位:printf("%02d:%02d:%02d\n", h, m, s);,2是补成几位,0是前面补的东西;

4.(cin>>n).get();

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值