热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

C语言借书方案知多少代码解析

nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd

问题描述

小明有5本新书,要借给A、B、C这3位小朋友,若每人每次只能借1本,则可以有多少种不同的借法?

问题分析

本题属于数学当中常见的排列组合问题,即求从5个数中取3个不同数的排列组合的总数。可以将5本书进行1〜5的编号,A、B、C 3个人每次都可以从5本书中任选1本,即每人都有5种选择,由于1本书不可能同时借给一个以上的人,因此只要这3个人所选书的编号不同,即为一次有效的借阅方法。

算法设计

对于每个人所选书号,可以采用穷举循环来实现,即从每个人可选书号(1、2、 3、4、5)的范围内进行穷举,从而得到可行的结果。对第1个人的选择,可以用循环将其列出:for(a=1;  a<=5;  a++),对于第2个人、第3个人可以用同样的方法。由于一本书只能借给一个人,所以第2个人的选择会受到第1个人的限制,最后一个人的选择会受到第2个人的限制,即后面的选择都是在前面选择的前提下进行的,所以可釆用循环的嵌套来解决问题。

下面是完整的代码:

#include
int main()
{
    int a, b, c, i=0;  /*a,b,c分别用来记录三个人所选新书编号,i用来控制有效借阅次数*/
    printf("A,B,C三人所选书号分别为:\n");
    for(a=1; a<=5; a++)  /*用来控制A借阅图书编号*/
        for(b=1; b<=5; b++)  /*用来控制B借阅图书编号*/
            for(c=1; c<=5; c++)  /*用来控制C借阅图书编号*/
                if(a!=b && a!=c && c!=b)  /*此条件用来控制有效借阅组合*/
                {
                    printf("A:%2d B:%2d c:%2d  ", a, b, c);
                    i++;
                    if(i%4==0)
                        printf("\n");
                }  /*每行最多输出4种借阅方法组合*/

    printf("共有%d种有效借阅方法\n",i);  /*输出有效的借阅方法总数*/

    return 0;
}

运行结果:

A,B,C三人所选书号分别为:
A: 1 B: 2 c: 3  A: 1 B: 2 c: 4  A: 1 B: 2 c: 5  A: 1 B: 3 c: 2 
A: 1 B: 3 c: 4  A: 1 B: 3 c: 5  A: 1 B: 4 c: 2  A: 1 B: 4 c: 3 
A: 1 B: 4 c: 5  A: 1 B: 5 c: 2  A: 1 B: 5 c: 3  A: 1 B: 5 c: 4 
A: 2 B: 1 c: 3  A: 2 B: 1 c: 4  A: 2 B: 1 c: 5  A: 2 B: 3 c: 1 
A: 2 B: 3 c: 4  A: 2 B: 3 c: 5  A: 2 B: 4 c: 1  A: 2 B: 4 c: 3 
A: 2 B: 4 c: 5  A: 2 B: 5 c: 1  A: 2 B: 5 c: 3  A: 2 B: 5 c: 4 
A: 3 B: 1 c: 2  A: 3 B: 1 c: 4  A: 3 B: 1 c: 5  A: 3 B: 2 c: 1 
A: 3 B: 2 c: 4  A: 3 B: 2 c: 5  A: 3 B: 4 c: 1  A: 3 B: 4 c: 2 
A: 3 B: 4 c: 5  A: 3 B: 5 c: 1  A: 3 B: 5 c: 2  A: 3 B: 5 c: 4 
A: 4 B: 1 c: 2  A: 4 B: 1 c: 3  A: 4 B: 1 c: 5  A: 4 B: 2 c: 1 
A: 4 B: 2 c: 3  A: 4 B: 2 c: 5  A: 4 B: 3 c: 1  A: 4 B: 3 c: 2 
A: 4 B: 3 c: 5  A: 4 B: 5 c: 1  A: 4 B: 5 c: 2  A: 4 B: 5 c: 3 
A: 5 B: 1 c: 2  A: 5 B: 1 c: 3  A: 5 B: 1 c: 4  A: 5 B: 2 c: 1 
A: 5 B: 2 c: 3  A: 5 B: 2 c: 4  A: 5 B: 3 c: 1  A: 5 B: 3 c: 2 
A: 5 B: 3 c: 4  A: 5 B: 4 c: 1  A: 5 B: 4 c: 2  A: 5 B: 4 c: 3 
共有60种有效借阅方法

#C语言借书方案知多少代码解析

知识点补充

利用循环解决问题的时候,找到循环的三要素:循环变量的初值、循环的控制条件,以及使循环趋于结束的循环变量值的改变是进行编程的关键。读者可参照第一个例子来找一下本题中所对应的循环三要素。本题的输出结果有一个条件限制,即3个人所选书号各不相同。在输出语句前只要用一个if语句if(a!=b && a!=c && c!=b)判断即可。


推荐阅读
  • Python 数据可视化实战指南
    本文详细介绍如何使用 Python 进行数据可视化,涵盖从环境搭建到具体实例的全过程。 ... [详细]
  • 网络爬虫的规范与限制
    本文探讨了网络爬虫引发的问题及其解决方案,重点介绍了Robots协议的作用和使用方法,旨在为网络爬虫的合理使用提供指导。 ... [详细]
  • 微软推出Windows Terminal Preview v0.10
    微软近期发布了Windows Terminal Preview v0.10,用户可以在微软商店或GitHub上获取这一更新。该版本在2月份发布的v0.9基础上,新增了鼠标输入和复制Pane等功能。 ... [详细]
  • window下的python安装插件,Go语言社区,Golang程序员人脉社 ... [详细]
  • Android开发技巧:使用IconFont减少应用体积
    本文介绍如何在Android应用中使用IconFont来显示图标,从而有效减少应用的体积。 ... [详细]
  • 第二十五天接口、多态
    1.java是面向对象的语言。设计模式:接口接口类是从java里衍生出来的,不是python原生支持的主要用于继承里多继承抽象类是python原生支持的主要用于继承里的单继承但是接 ... [详细]
  • 近期在研究逆向工程,因此尝试了一些CTF题目。通过合天网络安全实验室的CTF实战演练平台(http://www.hetianlab.com/CTFrace.html),我对Linux逆向工程的掌握还不够深入,因此暂时跳过了RE300题目。首先从逆向100开始,将文件后缀名修改为.apk进行初步分析。这一过程不仅帮助我熟悉了基本的逆向技巧,还加深了对Android应用结构的理解。 ... [详细]
  • Shell脚本编译器的全面解析与应用指南 ... [详细]
  • Linux下MySQL 8.0.28安装指南
    本文详细介绍了在Linux系统上安装MySQL 8.0.28的步骤,包括下载数据库、解压数据包、安装必要组件和启动MySQL服务。 ... [详细]
  • 本文详细介绍了在 Ubuntu 系统上搭建 Hadoop 集群时遇到的 SSH 密钥认证问题及其解决方案。通过本文,读者可以了解如何在多台虚拟机之间实现无密码 SSH 登录,从而顺利启动 Hadoop 集群。 ... [详细]
  • importpymysql#一、直接连接mysql数据库'''coonpymysql.connect(host'192.168.*.*',u ... [详细]
  • 原文网址:https:www.cnblogs.comysoceanp7476379.html目录1、AOP什么?2、需求3、解决办法1:使用静态代理4 ... [详细]
  • 两个条件,组合控制#if($query_string~*modviewthread&t(&extra(.*)))?$)#{#set$itid$1;#rewrite^ ... [详细]
  • Ansible:自动化运维工具详解
    Ansible 是一款新兴的自动化运维工具,基于 Python 开发,集成了多种运维工具(如 Puppet、CFEngine、Chef、Func 和 Fabric)的优点,实现了批量系统配置、程序部署和命令执行等功能。本文将详细介绍 Ansible 的架构、特性和优势。 ... [详细]
  • 本文讨论了在进行 MySQL 数据迁移过程中遇到的所有 .frm 文件报错的问题,并提供了详细的解决方案和建议。 ... [详细]
author-avatar
帅哥不潮_460
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有