PTA 中国大学MOOC-陈越、何钦铭-数据结构-起步能力自测题第一题

刚开始自学编程,这么一个简单的题目居然做了很久,果然书看千遍不如手打一遍T_T


#include <stdio.h>

#include <stdlib.h>

void space_print(int i);

void character_print(int i,char ch);

void pro_print(int i);

void con_print(int i);

int n ;char ch;

//n是输入的总字符数

int main(void)

{

int print_character(int n,char ch);

scanf("%d %c",&n,&ch);

print_character(n,ch);

return 0;

}

int print_character(int n ,char ch){

int i,row,small,last_c;

//row是半个沙漏的行数

if (n <= 0)

{

return -1;

}

else{

small=0 ;i=0;

while (small<n){

small=2*i*i+4*i+1;

i+=1;

}

row=i-1;

last_c=n-2*(row-1)*(row-1)-4*(row-1)-1;

return 0;

}

if(1==n) last_c=0;

pro_print(row);

space_print(row-1);

character_print(1,ch);

printf("\n");

con_print(row);

printf("%d",last_c);

//printf("\ni is %d and row is %d and last_c is %d",i,row,last_c);

}

//打印从多到少的沙漏形状直到中间

void pro_print(int i){

for (int j = 0; j < (i - 1); ++j)

{

space_print(j);

character_print(2*(i-j)-1,ch);

printf("\n");

}

}

//打印从少到多的沙漏形状直到底部

void con_print(int i){

int j;

for(j=0;j<(i-1);j++){

space_print(i-j-2);

character_print(2*j+3,ch);

printf("\n");

}

}

//打印指定数量的空格用于形成沙漏的形状

void space_print(int i){

for (int j = 0; j < i; ++j)

{

printf(" ");

}

}

//打印指定数量的指定字符

void character_print(int i,char ch){

int j;

for (int j = 0; j < i; ++j)

{

printf("%c",ch);

}

}

有个问题:当n=1的时候剩余字符数会有错误,为了通过测试强行加了一句

if(1==n) last_c=0;

菜的不忍直视

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 3,417评论 0 2
  • 【程序1】 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔...
    开心的锣鼓阅读 3,347评论 0 9
  • 【程序1】 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一...
    阿里高级软件架构师阅读 3,314评论 0 19
  • 学习不用力的专注,把工作转化为游戏,让你愿意承受的轭变得不费力,让你背负的担子变得轻松。
    袁克非阅读 194评论 0 1
  • 将对象组合成树形结构以表示“部分-整体”的层次结构,使得用户对单个对象和组合对象的使用具有一致性,以便能够让客户端...
    Ant_way阅读 502评论 0 0