C语言算法练习之佩奇借书

 更新时间:2022年03月23日 17:13:01   作者:飞向星的客机  
这篇文章主要该大家分享C语言佩奇借书的练习,文章主要通过描述佩奇借书的问题然后确定程序框架将结果运算出来,下面来看详细内容吧,需要的朋友可以参考一下

1. 问题描述

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

2. 题目分析

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

3. 算法设计

对于每个人所选书号,我们可以采用穷举循环来实现,即从每个人可选书号(1、2、3、4、5)的范围内进行穷举,从而得到可行的结果。 对第 1 个人的选择,我们可以用循环将其列出::for (a = 1; a <= 5; a++),同理对于第 2 个人、第 3 个人可以用同样的方法。 由于一本书只能借给一个人,所以第 2 个人的选择会受到第 1 个人的限制,最后一个人的选择会受到第 2 个人的限制,即后面的选择都是在前面选择的前提下进行的,所以可采用循环的嵌套来解决问题。 利用循环解决问题的时候,找到循环的三要素:循环变量的初值、循环的控制条件,以及使循环趋于结束的循环变量值的改变是进行编程的关键。

4. 代码实现

完整代码📝

int main()
{
	int a, b, c = 0; //a、b、c分别用来记录3个人所选新书编号
	int cnt = 0; //用来统计借阅的方法

	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:%d号  B:%d号  C:%d号  |  ", a, b, c);
					cnt++;

					if (cnt % 4 == 0) //打印4列在屏幕上显示
					{
						printf("\n");
					}
				}
			}
		}
	}
	printf("总共有%d种有效的借阅方法\n", cnt); //输出有效的借阅方法总数

	return 0;
}

运行结果👇

本题的输出结果有一个条件限制,即 3 个人所选书号各不相同,所以在输出语句前只要用一个 if 语句 if(a!=b && a!=c && c!=b)判断即可。

5. 算法升级

对于原程序中的第三层 for 循环来说不管 a、b 的取值是否相同,循环都要重复进行 5 次。 如果A 和 B 所选书号相同,那么无论 C 选什么书号都是无效的借阅方法。因此在执行第 3 个循环之前可先行判定A、B 两人的编号是否相同,进而提高程序效率。

修改后的程序在进入循环体之前首先判断a、b的取值,如果两者取值相同,内层循环无须重复执行5次便可结束。

完整代码📝

到此这篇关于C语言算法练习之佩奇借书的文章就介绍到这了,更多相关C语言 佩奇借书内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C语言实现全排列算法模板的方法

    C语言实现全排列算法模板的方法

    这篇文章主要介绍了C语言实现全排列算法模板的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-02-02
  • C语言代码详细描述顺序线性表

    C语言代码详细描述顺序线性表

    这篇文章主要用代码介绍了C语言线性表的顺序线性表,对于学习数据结构与算法的朋友很有参考借鉴价值,需要的朋友可以参考下
    2021-09-09
  • C语言实现在windows服务中新建进程的方法

    C语言实现在windows服务中新建进程的方法

    这篇文章主要介绍了C语言实现在windows服务中新建进程的方法,涉及C语言进程操作的相关技巧,需要的朋友可以参考下
    2015-06-06
  • C++ 中类的拷贝、赋值、销毁的实例详解

    C++ 中类的拷贝、赋值、销毁的实例详解

    这篇文章主要介绍了C++ 中类的拷贝、赋值、销毁的实例详解的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下
    2017-09-09
  • C++ Boost Foreach超详细分析讲解

    C++ Boost Foreach超详细分析讲解

    Boost是为C++语言标准库提供扩展的一些C++程序库的总称。Boost库是一个可移植、提供源代码的C++库,作为标准库的后备,是C++标准化进程的开发引擎之一,是为C++语言标准库提供扩展的一些C++程序库的总称
    2022-11-11
  • 在QT5中实现求两个输入值的和并输出(实例)

    在QT5中实现求两个输入值的和并输出(实例)

    下面小编就为大家带来一篇在QT5中实现求两个输入值的和并输出(实例)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08
  • C++计算ICMP头的校验和实例

    C++计算ICMP头的校验和实例

    这篇文章主要介绍了C++计算ICMP头的校验和的方法,代码简单实用,对于校验ICMP报文来说有不错的实用价值,需要的朋友可以参考下
    2014-10-10
  • C语言中栈的两种实现方法详解

    C语言中栈的两种实现方法详解

    栈只允许在一端进行插入或删除操作的线性表。首先栈是一种线性表,但是限定这种线性表只能在某一端进行插入和删除操作,这篇文章主要介绍了C语言对栈的实现基本操作
    2021-08-08
  • 一篇文章带你入门C语言:数组

    一篇文章带你入门C语言:数组

    这篇文章主要介绍了C语言中数组的一些基本知识小结,其中重点是对于数组的内存分配相关方面的知识整理,需要的朋友可以参考下
    2021-08-08
  • C语言实现古代时辰计时与现代时间换算

    C语言实现古代时辰计时与现代时间换算

    这篇文章主要为大家详细介绍了如何利用C语言实现古代时辰计时与现代时间换算,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下
    2023-03-03

最新评论