【C语言程序设计——循环程序设计】枚举法换硬币(头歌实践教学平台习题)【合集】

目录😋

任务描述

相关知识

 一、循环控制 / 跳转语句的使用

1. 循环控制语句(for 循环)

2. 循环控制语句(while 循环)

3. 跳转语句(break 语句)

4. 跳转语句(continue 语句)

二、循环嵌套语句

1. 基本概念

2. for 循环嵌套

3. while 循环嵌套

4. do - while 循环嵌套

5. 注意事项

编程要求

测试说明

通关代码

测试结果


任务描述

本关任务:运用枚举法求解硬币等额兑换的程序。


相关知识

为了完成本关任务,你需要掌握:

  1. 循环控制/跳转语句
  2. 循环嵌套语句;

 一、循环控制 / 跳转语句的使用

1. 循环控制语句(for 循环)
  • 基本原理for循环是一种常用的循环结构,它允许您指定一个初始化表达式、一个循环条件和一个更新表达式。语法格式为for(初始化表达式; 循环条件; 更新表达式)。初始化表达式在循环开始时执行一次,用于初始化循环变量。循环条件在每次循环迭代开始时进行检查,如果为真,则执行循环体中的代码。更新表达式在每次循环体执行完后执行,用于更新循环变量。
  • 示例代码
    #include <stdio.h>
    int main() {
        // 打印1到10的数字
        for (int i = 1; i <= 10; i++) {
            printf("%d ", i);
        }
        printf("\n");
        return 0;
    }
    
2. 循环控制语句(while 循环)
  • 基本原理while循环在循环开始时检查循环条件。只要条件为真,就会执行循环体中的代码。语法格式为while(循环条件)。循环条件是一个表达式,它返回一个布尔值(真或假)。在循环体中,通常需要包含一些能够改变循环条件的语句,否则可能会导致无限循环。
  • 示例代码
    #include <stdio.h>
    int main() {
        int i = 1;
        while (i <= 10) {
            printf("%d ", i);
            i++;
        }
        printf("\n");
        return 0;
    }
    
3. 跳转语句(break 语句)
  • 基本原理break语句用于立即跳出当前循环(forwhiledo - while)或switch语句。当程序执行到break语句时,循环或switch语句会立即终止,程序控制流将跳转到循环或switch语句后的下一条语句。
  • 示例代码(在循环中使用 break)
    #include <stdio.h>
    int main() {
        for (int i = 1; i <= 10; i++) {
            if (i == 5) {
                break;
            }
            printf("%d ", i);
        }
        printf("\n");
        return 0;
    }
    
4. 跳转语句(continue 语句)
  • 基本原理continue语句用于跳过当前循环迭代的剩余部分,直接开始下一次循环迭代。当程序执行到continue语句时,循环体中continue语句之后的代码将不会被执行,而是直接跳转到循环的更新表达式(对于for循环)或循环条件检查(对于whiledo - while循环)。
  • 示例代码(在循环中使用 continue)
    #include <stdio.h>
    int main() {
        for (int i = 1; i <= 10; i++) {
            if (i == 5) {
                continue;
            }
            printf("%d ", i);
        }
        printf("\n");
        return 0;
    }

二、循环嵌套语句

1. 基本概念

循环嵌套是指在一个循环语句的循环体中又包含另一个循环语句。在 C 语言中,for循环、while循环和do - while循环都可以相互嵌套。它主要用于处理具有多重循环结构的问题,例如二维数组的遍历、打印各种有规律的图案等。

2. for 循环嵌套
  • 语法结构

最常见循环嵌套结构是for循环嵌套for循环。其基本形式如下:

for(初始化表达式1; 条件表达式1; 更新表达式1) {
    // 外层循环体
    for(初始化表达式2; 条件表达式2; 更新表达式2) {
        // 内层循环体
    }
}

下面的代码打印了一个简单的乘法口诀表:

#include <stdio.h>
int main() {
    int i, j;
    for(i = 1; i <= 9; i++) {
        for(j = 1; j <= i; j++) {
            printf("%d*%d=%d\t", j, i, i * j);
        }
        printf("\n");
    }
    return 0;
}

其中,外层for循环控制行数(i从 1 到 9),内层for循环控制每行乘法口诀的列数(j从 1 到当前行号i)。每次内层循环结束后,会输出一个换行符,形成了一个完整的乘法口诀表。

3. while 循环嵌套
  • 语法结构

基本形式如下:

while(条件表达式1) {
    // 外层循环体
    while(条件表达式2) {
        // 内层循环体
    }
}

例如,下面的代码用于计算两个数的最大公因数,使用的是辗转相除法(欧几里得算法),可以用while循环嵌套来实现:

#include <stdio.h>
int main() {
    int a, b, temp;
    printf("请输入两个整数:");
    scanf("%d %d", &a, &b);
    while (b!= 0) {
        temp = a % b;
        a = b;
        b = temp;
    }
    printf("最大公因数是:%d\n", a);
    return 0;
}

这里,外层while循环用于不断更新ab的值,直到b变为 0,内层的操作(计算余数并更新ab)在每次外层循环迭代时都会执行。

4. do - while 循环嵌套
  • 语法结构

基本形式如下:

do {
    // 外层循环体
    do {
        // 内层循环体
    } while(条件表达式2);
} while(条件表达式1);

例如,下面的代码可以用于模拟一个简单的游戏关卡选择界面,假设游戏有多个章节,每个章节有多个关卡,用户可以选择章节和关卡:

#include <stdio.h>
int main() {
    int chapter, level;
    do {
        printf("请选择章节(1 - 3):");
        scanf("%d", &chapter);
        if (chapter >= 1 && chapter <= 3) {
            do {
                printf("请选择章节 %d中的关卡(1 - 5):", chapter);
                scanf("%d", &level);
                if (level >= 1 && level <= 5) {
                    printf("你选择了章节 %d的关卡 %d\n", chapter, level);
                } else {
                    printf("无效的关卡选择。\n");
                }
            } while (level < 1 || level > 5);
        } else {
            printf("无效的章节选择。\n");
        }
    } while (chapter < 1 || chapter > 3);
    return 0;
}

其中,外层do - while循环用于确保用户选择了有效的章节(1 - 3),内层do - while循环用于确保用户在选定的章节中选择了有效的关卡(1 - 5)。

5. 注意事项
  • 循环嵌套时,要特别注意内层循环和外层循环的控制变量。它们应该相互独立,避免在内层循环中意外修改外层循环的控制变量,除非这是有意为之并且经过仔细考虑的逻辑。
  • 随着循环嵌套层数的增加,程序的复杂度也会增加。因此,在编写循环嵌套代码时,要确保代码的可读性,必要时添加注释来解释代码的功能和意图。同时,要注意循环嵌套可能带来的性能问题,例如过多的嵌套可能导致程序运行时间过长或者占用过多的内存资源。

编程要求

根据提示在右侧编辑器Begin--End之间的区域内补充必要的代码。


测试说明

平台会对你编写的代码进行测试:

预期输出:

1fen:  5 ,2fen: 10 ,5fen: 15
1fen:  5 ,2fen: 35 ,5fen:  5
1fen: 10 ,2fen: 20 ,5fen: 10
1fen: 15 ,2fen:  5 ,5fen: 15
1fen: 15 ,2fen: 30 ,5fen:  5
1fen: 20 ,2fen: 15 ,5fen: 10
1fen: 25 ,2fen: 25 ,5fen:  5
1fen: 30 ,2fen: 10 ,5fen: 10
1fen: 35 ,2fen: 20 ,5fen:  5
1fen: 40 ,2fen:  5 ,5fen: 10
1fen: 45 ,2fen: 15 ,5fen:  5
1fen: 55 ,2fen: 10 ,5fen:  5
1fen: 65 ,2fen:  5 ,5fen:  5
一共有13种

开始你的任务吧,祝你成功!


通关代码

/*6.要将一元钱换成1分、2分和5分的硬币,每种硬币的个数大于0,且为5的倍数,
编写程序计算并输出有多少种换法。*/
#include<stdio.h>
main(){
	int i,j,k,n=0;
	   /************************begin***********************/
    for(i=1;i<100;i++){
        for(j=1;j<=50;j++){
            for(k=1;k<20;k++){
                if(i+2*j+5*k==100 && i%5==0 && j%5==0 && k%5==0){
                    n++;
                    printf("1fen: %2d ,2fen: %2d ,5fen: %2d\n",i,j,k);
                    }
                }
            }
        }  
       /************************end************************/
	printf( "一共有%d种",n);
}

测试结果

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/947483.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

SD-WAN怎样减少异地组网的网络延迟?

在经济全球化的推动下&#xff0c;许多企业的业务已经扩展到多个国家或地区。这种情况下&#xff0c;企业需要搭建高效、稳定的网络连接&#xff0c;以确保异地的分支机构之间能够顺畅地交流。网络延迟是拉低异地组网数据传输效率的重要因素&#xff0c;直接影响到企业的运营和…

小程序学习06——uniapp组件常规引入和easycom引入语法

目录 一 组件注册 1.1 组件全局注册 1.2 组件全局引入 1.3 组件局部引入 页面引入组件方式 1.3.1 传统vue规范&#xff1a; 1.3.2 通过uni-app的easycom 二 组件的类型 2.1 基础组件列表 一 组件注册 1.1 组件全局注册 &#xff08;a&#xff09;新建compoents文件…

uniapp 微信小程序 自定义日历组件

效果图 功能&#xff1a;可以记录当天是否有某些任务或者某些记录 具体使用&#xff1a; 子组件代码 <template><view class"Accumulate"><view class"bx"><view class"bxx"><view class"plank"><…

上升沿下降沿递增

沿指令&#xff1a;P&#xff1a;上升沿 从01 导通一个扫描周期 N&#xff1a;下降沿 从10 导通一个扫描周期

大数据-268 实时数仓 - ODS层 将 Kafka 中的维度表写入 DIM

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; Java篇开始了&#xff01; MyBatis 更新完毕目前开始更新 Spring&#xff0c;一起深入浅出&#xff01; 目前已经更新到了&#xff1a; H…

微博_14.12.2-内置猪手 会员版

微博猪手是一款作用于微博的 XposedLsposed 模块&#xff0c;可以支持未root用户和已root用户使用。进入【我的】页面&#xff0c;点击【右上角的设置】&#xff0c;点击【微博猪手】即可进一步设置其他功能。通过微博猪手模块可以实现去除各种广告&#xff08;开屏、信息流等&…

计算机网络 (21)网络层的几个重要概念

前言 计算机网络中的网络层是OSI&#xff08;开放系统互连&#xff09;模型中的第三层&#xff0c;也是TCP/IP模型中的第二层&#xff0c;它位于数据链路层和传输层之间&#xff0c;负责数据包从源主机到目的主机的路径选择和数据转发。 一、网络层的主要功能 路由选择&#xf…

openwrt nginx UCI配置过程

openwrt 中nginx有2种配置方法&#xff0c;uci nginx uci /etc/config/nginx 如下&#xff1a; option uci_enable true‘ 如果是true就是使用UCI配置&#xff0c;如果 是false&#xff0c;就要使用/etc/nginx/nginx.conf&#xff0c;一般不要修改。 如果用UCI&#xff0c;其…

【深度学习进阶】基于CNN的猫狗图片分类项目

介绍 基于卷积神经网络&#xff08;CNN&#xff09;的猫狗图片分类项目是机器学习领域中的一种常见任务&#xff0c;它涉及图像处理和深度学习技术。以下是该项目的技术点和流程介绍&#xff1a; 技术点 卷积神经网络 (CNN): CNN 是一种专门用于处理具有类似网格结构的数据的…

uni-app 页面生命周期及组件生命周期汇总(Vue2、Vue3)

文章目录 一、前言&#x1f343;二、页面生命周期三、Vue2 页面及组件生命周期流程图四、Vue3 页面及组件生命周期流程图4.1 页面加载时序介绍4.2 页面加载常见问题4.3 onShow 和 onHide4.4 onInit4.5 onLoad4.6 onReachBottom4.7 onPageScroll4.8 onBackPress4.9 onTabItemTap…

缓存淘汰算法:次数除以时间差

记录缓存中的每一项的访问次数、最后访问时间&#xff0c;获取当前时间&#xff0c;可算出时间差&#xff0c;然后&#xff0c;用次数除以时间差&#xff0c;取最小的淘汰。 这一算法比较慢&#xff0c;需配合多级缓存。一级缓存不很大&#xff0c;使用此算法。二级缓存可以大…

uniapp 微信小程序开发使用高德地图、腾讯地图

一、高德地图 1.注册高德地图开放平台账号 &#xff08;1&#xff09;创建应用 这个key 第3步骤&#xff0c;配置到项目中locationGps.js 2.下载高德地图微信小程序插件 &#xff08;1&#xff09;下载地址 高德地图API | 微信小程序插件 &#xff08;2&#xff09;引入项目…

Mac iTerm2集成DeepSeek AI

1. 去deepseek官网申请api key&#xff0c;DeepSeek 2. 安装iTerm2 AI Plugin插件&#xff0c;https://iterm2.com/ai-plugin.html&#xff0c;插件解压后直接放到和iTerms相同的位置&#xff0c;默认就在/Applications 下 3. 配置iTerm2 4. 重启iTerm2,使用快捷键呼出AI对话…

树莓派 Pico RP2040 教程点灯 双核编程案例

双核点亮不同的 LED 示例&#xff0c;引脚分别是GP0跟GP1。 #include "pico/stdlib.h" #include "pico/multicore.h"#define LED1 0 // 核心 0 控制的 LED 引脚 #define LED2 1 // 核心 1 控制的 LED 引脚// the setup function runs once when you press …

简单使用linux

1.1 Linux的组成 Linux 内核&#xff1a;内核是系统的核心&#xff0c;是运行程序和管理 像磁盘和打印机等硬件设备的核心程序。 文件系统 : 文件存放在磁盘等存储设备上的组织方法。 Linux 能支持多种目前浒的文件系统&#xff0c;如 ext4 、 FAT 、 VFAT 、 ISO9660 、 NF…

ACM算法模板

ACM算法模板 起手式基础算法前缀和与差分二分查找三分查找求极值分治法&#xff1a;归并排序 动态规划基本线性 d p dp dp最长上升子序列I O ( n 2 ) O(n ^ 2) O(n2)最长上升子序列II O ( n l o g n ) O(nlogn) O(nlogn) 贪心二分最长公共子序列 背包背包求组合种类背包求排列…

《Vue3实战教程》19:Vue3组件 v-model

如果您有疑问&#xff0c;请观看视频教程《Vue3实战教程》 组件 v-model​ 基本用法​ v-model 可以在组件上使用以实现双向绑定。 从 Vue 3.4 开始&#xff0c;推荐的实现方式是使用 defineModel() 宏&#xff1a; vue <!-- Child.vue --> <script setup> co…

Docker 环境中搭建 Redis 哨兵模式集群的步骤与问题解决

在 Docker 环境中搭建 Redis 哨兵模式集群的步骤与问题解决 在 Redis 高可用架构中&#xff0c;哨兵模式&#xff08;Sentinel&#xff09;是确保 Redis 集群在出现故障时自动切换主节点的一种机制。通过使用 Redis 哨兵&#xff0c;我们可以实现 Redis 集群的监控、故障检测和…

数据结构:时间复杂度和空间复杂度

我们知道代码和代码之间算法的不同&#xff0c;一定影响了代码的执行效率&#xff0c;那么我们该如何评判算法的好坏呢&#xff1f;这就涉及到了我们算法效率的分析了。 &#x1f4d6;一、算法效率 所谓算法效率的分析分为两种&#xff1a;第一种时间效率&#xff0c;又称时间…

《Vue3实战教程》39:Vue3无障碍访问

如果您有疑问&#xff0c;请观看视频教程《Vue3实战教程》 无障碍访问​ Web 无障碍访问 (也称为 a11y) 是指创建可供任何人使用的网站的做法——无论是身患某种障碍、通过慢速的网络连接访问、使用老旧或损坏的硬件&#xff0c;还是仅处于某种不方便的环境。例如&#xff0c;…