剖析SQLsever之01-百钱白鸡-C/sqlsever存储过程

2023-11-11 12:40

本文主要是介绍剖析SQLsever之01-百钱白鸡-C/sqlsever存储过程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目及分析原链接如下:
http://c.biancheng.net/view/500.html
参考链接:https://www.cnblogs.com/huangxincheng/archive/2012/08/05/2624156.html

1.1、问题如下:

我国古代数学家张丘建在《算经》一书中曾提出过著名的“百钱买百鸡”问题,该问题叙述如下:鸡翁一,值钱五;鸡母一,值钱三;鸡雏三,值钱一;百钱买百鸡,则翁、母、雏各几何?
翻译过来,意思是公鸡一个五块钱,母鸡一个三块钱,小鸡三个一块钱,现在要用一百块钱买一百只鸡,问公鸡、母鸡、小鸡各多少只?

1.2.、题目分析

如果用数学的方法解决百钱买百鸡问题,可将该问题抽象成方程式组。设公鸡 x 只,母鸡 y 只,小鸡 z 只,得到以下方程式组:
A:5x+3y+1/3z = 100
B:x+y+z = 100
C:0 <= x <= 100
D:0 <= y <= 100
E:0 <= z <= 100

如果用解方程的方式解这道题需要进行多次猜解,计算机的一个优势就是计算速度特别暴力并且无怨无悔,所以我们可以欺负她、蹂躏她!因此我们用穷举法的方式来解题,需要 101^3 次猜解,但对于计算机来说,小 CASE!

1.3、代码如下

1.3.1、C语言

方法一:时间复杂度为 O(n^3)

// hundred chickens.cpp : Defines the entry point for the console application.
//#include "stdafx.h"int main(int argc, char* argv[])
{printf("百元买百鸡的问题所有可能的解如下:\n");int cock,hen,chicken;for( cock=0; cock<21; cock++)for( hen=0; hen<34; hen++)for ( chicken=0; chicken<300; chicken++)if( cock*5+hen*3+chicken/3==100 && cock+hen+chicken==100 && chicken%3==0 )printf("公鸡 %2d 只,母鸡 %2d 只,小鸡 %2d 只\n", cock, hen, chicken);return 0;
}

方法二:时间复杂度为 O(n^2)

// hundred chickens.cpp : Defines the entry point for the console application.
//#include "stdafx.h"int main(int argc, char* argv[])
{printf("百元买百鸡的问题所有可能的解如下:\n");int cock,hen,chicken;chicken=0;for( cock=0; cock<21; cock++)for( hen=0; hen<34; hen++) {chicken = 100-cock-hen;if( cock*5+hen*3+chicken/3==100 && chicken%3==0 )printf("公鸡 %2d 只,母鸡 %2d 只,小鸡 %2d 只\n", cock, hen, chicken);}return 0;
}

方法三:时间复杂度为O(n)
从结果中我们可以发现这样的一个规律:公鸡是4的倍数,母鸡是7的递减率,小鸡是3的递增率,规律哪里来,肯定需要我们推算一下这个不定方程。

x+y+z=100          ①
5x+3y+z/3=100    ②

令②*3-① 可得

7x+4y=100
=>y=25-(7/4)x          ③

又因为0<y<100的自然数,则可令

 x=4k                    ④

将④代入③可得
=> y=25-7k ⑤

将④⑤代入①可知
=> z=75+3k ⑥

要保证0<=x,y,z<100的话,k的取值范围只能是1,2,3,4,下面我们继续上代码。

// hundred chickens.cpp : Defines the entry point for the console application.
//#include "stdafx.h"int main(int argc, char* argv[])
{printf("百元买百鸡的问题所有可能的解如下:\n");int cock,hen,chicken,k;cock=hen=chicken=k=0;for(k=0; k<5; k++){cock = 4*k;hen = 25-7*k;chicken = 75+3*k;printf("公鸡 %2d 只,母鸡 %2d 只,小鸡 %2d 只\n", cock, hen, chicken);}return 0;
}

输出:
在这里插入图片描述

1.2、sqlsever存储过程

方法一:等同于C语言,方法三

print '百元买百鸡的问题所有可能的解如下:'declare @cock int,@hen int,@chicken int,@k int
--cock:公鸡 hen:母鸡 chicken:小鸡 
set @cock=0
set @hen=0
set @chicken=0
set @k=0
while @k<5
beginset @cock=4*@kselect @hen=25-7*@kselect @chicken=75+3*@kselect @k=@k+1print @cockprint @henprint @chicken
end

方法二:暴力穷举—额,太慢了,跑了很久都没有结果

--百钱买鸡
/*
鸡翁一,值钱五;鸡母一,值钱三;鸡雏三,值钱一;
百钱买百鸡,则翁、母、雏各几何?
*/print '百元买百鸡的问题所有可能的解如下:'declare @cock int,@hen int,@chicken int,@sum int,@money int
--cock:公鸡 hen:母鸡 chicken:小鸡 sum:鸡的总数 money:买sum只鸡所花的钱
set @cock=0
set @hen=0
set @chicken=0
set @sum=0
set @money=0
while @cock<=20 
beginwhile @hen<34beginwhile @chicken<=100beginselect @money=5*@cock+3*@hen+@chicken/3select @sum=@cock+@hen+@chickenif(@money=100 and @sum=100)beginprint '公鸡='+@cockprint '母鸡='+@henprint '小鸡='+@chickenendendend
end

这篇关于剖析SQLsever之01-百钱白鸡-C/sqlsever存储过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/390126

相关文章

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

redis群集简单部署过程

《redis群集简单部署过程》文章介绍了Redis,一个高性能的键值存储系统,其支持多种数据结构和命令,它还讨论了Redis的服务器端架构、数据存储和获取、协议和命令、高可用性方案、缓存机制以及监控和... 目录Redis介绍1. 基本概念2. 服务器端3. 存储和获取数据4. 协议和命令5. 高可用性6.

PLsql Oracle 下载安装图文过程详解

《PLsqlOracle下载安装图文过程详解》PL/SQLDeveloper是一款用于开发Oracle数据库的集成开发环境,可以通过官网下载安装配置,并通过配置tnsnames.ora文件及环境变... 目录一、PL/SQL Developer 简介二、PL/SQL Developer 安装及配置详解1.下

在Java中使用ModelMapper简化Shapefile属性转JavaBean实战过程

《在Java中使用ModelMapper简化Shapefile属性转JavaBean实战过程》本文介绍了在Java中使用ModelMapper库简化Shapefile属性转JavaBean的过程,对比... 目录前言一、原始的处理办法1、使用Set方法来转换2、使用构造方法转换二、基于ModelMapper

springboot启动流程过程

《springboot启动流程过程》SpringBoot简化了Spring框架的使用,通过创建`SpringApplication`对象,判断应用类型并设置初始化器和监听器,在`run`方法中,读取配... 目录springboot启动流程springboot程序启动入口1.创建SpringApplicat

本地搭建DeepSeek-R1、WebUI的完整过程及访问

《本地搭建DeepSeek-R1、WebUI的完整过程及访问》:本文主要介绍本地搭建DeepSeek-R1、WebUI的完整过程及访问的相关资料,DeepSeek-R1是一个开源的人工智能平台,主... 目录背景       搭建准备基础概念搭建过程访问对话测试总结背景       最近几年,人工智能技术

Redis存储的列表分页和检索的实现方法

《Redis存储的列表分页和检索的实现方法》在Redis中,列表(List)是一种有序的数据结构,通常用于存储一系列元素,由于列表是有序的,可以通过索引来访问元素,因此可以很方便地实现分页和检索功能,... 目录一、Redis 列表的基本操作二、分页实现三、检索实现3.1 方法 1:客户端过滤3.2 方法

Linux部署jar包过程

《Linux部署jar包过程》文章介绍了在Linux系统上部署Java(jar)包时需要注意的几个关键点,包括统一JDK版本、添加打包插件、修改数据库密码以及正确执行jar包的方法... 目录linux部署jar包1.统一jdk版本2.打包插件依赖3.修改密码4.执行jar包总结Linux部署jar包部署

C++中使用vector存储并遍历数据的基本步骤

《C++中使用vector存储并遍历数据的基本步骤》C++标准模板库(STL)提供了多种容器类型,包括顺序容器、关联容器、无序关联容器和容器适配器,每种容器都有其特定的用途和特性,:本文主要介绍C... 目录(1)容器及简要描述‌php顺序容器‌‌关联容器‌‌无序关联容器‌(基于哈希表):‌容器适配器‌:(

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB