C语言编程:图形输出、数字重组与马驮货物问题

版权申诉
0 下载量 68 浏览量 更新于2024-07-02 收藏 665KB DOC 举报
"这篇文档包含了三个C语言编程题目,涵盖了图形输出、数字处理以及数学问题的求解。" 1. **图形输出** 题目要求在屏幕上输出特定的图形,通过嵌套循环实现。外层循环控制行数,内层循环控制每行打印的空格和数字。在代码中,注释`$ERROR1$`处的`printf("%d",k)`用于打印数字,而`$ERROR2$`和`$ERROR3$`处的语句是错误的,因为它们没有实际作用。正确实现应为: ```c for(k=1;k<=i;k++) // 打印数字 printf("%d",k); for(j=i+1;j<6;j++) // 打印空格 printf(" "); ``` 内层循环打印空格后,应立即结束,无需设置额外的变量`j`。 2. **偶数位提取** 此题要求将长整型数`s`中每一位为偶数的数码依次取出,构成新数`t`。首先,`$BLANK1$`处应填入`k%2==0`,判断当前数码是否为偶数;`$BLANK2$`处应填入`s/10`,将`s`除以10,移除最低位;`$BLANK3$`处应填入`m>0`,在`m`不为0时继续循环。完整代码如下: ```c while(s > 0) { k = s % 10; if(k % 2 == 0) m = m * 10 + k; s = s / 10; } while(m > 0) { t = t * 10 + m % 10; m = m / 10; } ``` 3. **百马百担问题** 这是一个经典的数学问题,通过循环求解不同马匹组合满足条件的解。根据题目,大马(4担)、中马(3担)和小马(1担)的总和必须等于100担,同时每种马都必须有。可以使用穷举法或动态规划求解。然而,提供的代码仅仅是一个打印函数`PRINT`,没有实现求解过程。一个简单的穷举法示例: ```c int a = 0, b = 0, c = 0; for(a = 1; a <= 25; a++) { // 大马最多25匹(因为4*25=100) for(b = 1; b <= 33; b++) { // 中马最多33匹(因为3*33=99,留1给小马) c = 100 - (4*a + 3*b); // 计算小马数量 if(c >= 1 && c <= 20 && a + b + c == 100) { // 检查是否满足条件 PRINT(a, b, c); break; // 找到解后退出循环 } } } ``` 注意,实际的解决方案可能需要更复杂的算法来避免过多的循环计算。 总结来说,这个文档提供了三个关于C语言编程的题目,涉及了基本的循环结构、条件判断、数字处理以及简单的数学问题解决。通过解决这些问题,学习者可以加深对C语言控制结构的理解,并锻炼逻辑思维能力。