《算法竞赛入门经典 第二版》习题——Chapter 2

2024-06-21 05:38

本文主要是介绍《算法竞赛入门经典 第二版》习题——Chapter 2,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

习题2-1 水仙花数(daffodil)

#include<iostream>
#include<cstdio>
using namespace std;int main()
{int a, b, c;for (int num = 100; num < 1000; num++){a = num / 100;b = num / 10 % 10;c = num % 10;if (num == a*a*a + b*b*b + c*c*c)cout << num << " ";}cout << endl;
}

#include<iostream>
#include<cstdio>
using namespace std;int main()
{for (int num = 100; num < 1000; num++){int temp = num;int s = 0, a;while (temp){a = temp % 10;s += a*a*a;temp /= 10;}if (num == s)cout << num << " ";}cout << endl;
}


习题2-2 韩信点兵(hanxin)

#include<iostream>
#include<cstdio>
using namespace std;int main()
{int a, b, c;int count = 0;while (cin >> a >> b >> c){++count;int i;for (i = 10; i <= 100; i++){if (i % 3 == a && i % 5 == b && i % 7 == c){printf("Case %d: %d\n", count, i);break;}}if (i == 101){printf("Case %d: No answer\n", count);}}
}


习题2-3 倒三角形(triangle)

#include<iostream>
#include<cstdio>
using namespace std;int main()
{int n,b=0;cin >> n;for (; n > 0; n--,b++){for (int i = 0; i < b; i++)cout << " ";for (int j = 2*n-1; j >0; j--){cout << "#";}cout << endl;}return 0;
}


习题2-4 子序列的和(subsequence)

分析:本题陷阱在于n比较大时,n*n会溢出,可以用1/n/n替代1/n^2,或者将n*n强制转换为double

#include<iostream>
#include<cstdio>
using namespace std;int main()
{int  n, m;int kase = 0;while (cin >> n >> m && m!=0 || n!=0){++kase;double s = 0;for (long long  i = n; i <= m; i++){s += 1 / double(i*i);}printf("Case %d: %.5f\n", kase, s);}return 0;
}



习题2-5 分数化小数(decimal)

分析:printf("%*.*lf", x, y, z) 第一个*对应x,第二个*对应y,lf对应z (高级特性)

注:该方案不完善,有 bug~

#include<iostream>
#include<cstdio>
using namespace std;int main()
{int  a, b;int c = 0,kase=0;while (cin >> a >> b >> c && a!=0 || b!=0 || c!=0){++kase;double f =1.0 * a /b;printf("Case %d: %.*lf",kase, c, f);}return 0;
}


习题2-6 排列(permulation)

分析:思路其实就是穷举,首先可以判断出最小的数在123~329之间。利用一个数组a[1]~a[9],值为0表示没出现过,为1则表示出现,注意最后要清零!

#include<iostream>
#include<cstdio>
using namespace std;int main()
{int a[10] = { 0 };int b;for (int i = 123; i <= 329; i++){for (int j = 1; j <= 3; j++){int temp = i*j;while (temp){b = temp % 10;a[b] = 1;temp /= 10;}}b = 0;for (int k = 1; k < 10; k++)b += a[k];if (b == 9)printf("%d %d %d\n", i, i * 2, i * 3);for (int k = 0; k < 10; k++)a[k] = 0;}return 0;
}




这篇关于《算法竞赛入门经典 第二版》习题——Chapter 2的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringCloud Stream 快速入门实例教程

《SpringCloudStream快速入门实例教程》本文介绍了SpringCloudStream(SCS)组件在分布式系统中的作用,以及如何集成到SpringBoot项目中,通过SCS,可... 目录1.SCS 组件的出现的背景和作用2.SCS 集成srping Boot项目3.Yml 配置4.Sprin

SpringMVC配置、映射与参数处理​入门案例详解

《SpringMVC配置、映射与参数处理​入门案例详解》文章介绍了SpringMVC框架的基本概念和使用方法,包括如何配置和编写Controller、设置请求映射规则、使用RestFul风格、获取请求... 目录1.SpringMVC概述2.入门案例①导入相关依赖②配置web.XML③配置SpringMVC

MySQL索引踩坑合集从入门到精通

《MySQL索引踩坑合集从入门到精通》本文详细介绍了MySQL索引的使用,包括索引的类型、创建、使用、优化技巧及最佳实践,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录mysql索引完整教程:从入门到入土(附实战踩坑指南)一、索引是什么?为什么需要它?1.1 什么

Java Lettuce 客户端入门到生产的实现步骤

《JavaLettuce客户端入门到生产的实现步骤》本文主要介绍了JavaLettuce客户端入门到生产的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录1 安装依赖MavenGradle2 最小化连接示例3 核心特性速览4 生产环境配置建议5 常见问题

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

从入门到精通详解Python虚拟环境完全指南

《从入门到精通详解Python虚拟环境完全指南》Python虚拟环境是一个独立的Python运行环境,它允许你为不同的项目创建隔离的Python环境,下面小编就来和大家详细介绍一下吧... 目录什么是python虚拟环境一、使用venv创建和管理虚拟环境1.1 创建虚拟环境1.2 激活虚拟环境1.3 验证虚

Java List 使用举例(从入门到精通)

《JavaList使用举例(从入门到精通)》本文系统讲解JavaList,涵盖基础概念、核心特性、常用实现(如ArrayList、LinkedList)及性能对比,介绍创建、操作、遍历方法,结合实... 目录一、List 基础概念1.1 什么是 List?1.2 List 的核心特性1.3 List 家族成

c++日志库log4cplus快速入门小结

《c++日志库log4cplus快速入门小结》文章浏览阅读1.1w次,点赞9次,收藏44次。本文介绍Log4cplus,一种适用于C++的线程安全日志记录API,提供灵活的日志管理和配置控制。文章涵盖... 目录简介日志等级配置文件使用关于初始化使用示例总结参考资料简介log4j 用于Java,log4c

史上最全MybatisPlus从入门到精通

《史上最全MybatisPlus从入门到精通》MyBatis-Plus是MyBatis增强工具,简化开发并提升效率,支持自动映射表名/字段与实体类,提供条件构造器、多种查询方式(等值/范围/模糊/分页... 目录1.简介2.基础篇2.1.通用mapper接口操作2.2.通用service接口操作3.进阶篇3

Python自定义异常的全面指南(入门到实践)

《Python自定义异常的全面指南(入门到实践)》想象你正在开发一个银行系统,用户转账时余额不足,如果直接抛出ValueError,调用方很难区分是金额格式错误还是余额不足,这正是Python自定义异... 目录引言:为什么需要自定义异常一、异常基础:先搞懂python的异常体系1.1 异常是什么?1.2