当前位置: 首页 > news >正文

C基础寒假练习(2)

一、输出3-100以内的完美数,(完美数:因子和(因子不包含自身)=数本身

#include <stdio.h>// 函数声明
int isPerfectNumber(int num);int main() 
{printf("3-100以内的完美数有:\n");for (int i = 3; i <= 100; i++){if (isPerfectNumber(i)) {printf("%d\n", i);}}return 0;
}// 判断是否为完美数的函数
int isPerfectNumber(int num) 
{int sum = 1; // 1是所有正整数的因子for (int i = 2; i * i <= num; i++) {if (num % i == 0) {if (i * i != num) {sum += i + num / i;}else {sum += i;}}}return sum == num && num != 1;
}

以下是对代码的详细解释:
1. 函数声明:        
 

int isPerfectNumber(int num);

    这行代码声明了一个名为isPerfectNumber的函数,该函数接受一个整数参数并返回一个整数。
2. 主函数:        

int isPerfectNumber(int num) 
{int sum = 1; // 1是所有正整数的因子for (int i = 2; i * i <= num; i++) {if (num % i == 0) {if (i * i != num) {sum += i + num / i;}else {sum += i;}}}return sum == num && num != 1;
}

    这个函数用于判断一个数是否为完美数。具体步骤如下:
• 初始化sum为1,因为1是所有正整数的因子。
• 使用一个循环从2开始遍历到sqrt(num),检查每个数是否是num的因子。
• 如果i是num的因子,并且i*i不等于num,则将i和num/i都加到sum中。如果i*i等于num,则只加一次i。
• 最后,检查sum是否等于num且num不等于1。如果条件成立,则返回1(表示是完美数),否则返回0(表示不是完美数)。

二、百钱买百鸡问题,一百元钱去买鸡,公鸡5元,母鸡3元,三只小鸡1元,问买一百只鸡,有多少种买法。

#include <stdio.h>int main()  
{int rooster, hen, chick;int count = 0; // 用于记录符合条件的组合数for (rooster = 0; rooster <= 20; rooster++) { // 公鸡最多只能买20只(5*20=100)for (hen = 0; hen <= 33; hen++) { // 母鸡最多只能买33只(3*33=99)chick = 100 - rooster - hen; // 小鸡的数量由总数100减去公鸡和母鸡的数量得到if (chick % 3 == 0 && (5 * rooster + 3 * hen + chick / 3) == 100) { // 检查是否符合条件printf("Rooster: %d, Hen: %d, Chick: %d\n", rooster, hen, chick);count++;}}}printf("Total combinations: %d\n", count);return 0;
}

代码解释:
1. 变量声明:
• rooster:表示公鸡的数量。
• hen:表示母鸡的数量。
• chick:表示小鸡的数量。
• count:用于记录符合条件的组合数。
2. 循环结构:
• 外层循环遍历公鸡的数量,从0到20(因为每只公鸡5元,所以最多只能买20只)。
• 内层循环遍历母鸡的数量,从0到33(因为每只母鸡3元,所以最多只能买33只)。
• 计算小鸡的数量为100 - rooster - hen。
3. 条件判断:
• 检查小鸡的数量是否是3的倍数(因为三只小鸡1元)。
• 检查总价是否等于100元。
4. 输出结果:
• 如果符合条件,打印当前组合并增加计数器。
• 最后输出符合条件的组合总数。
运行这段代码,你将得到所有符合条件的组合以及组合的总数。

http://www.lryc.cn/news/531400.html

相关文章:

  • Baklib如何提升内容中台智能化推荐系统的精准服务与用户体验
  • 【Java】位图 布隆过滤器
  • 【专业标题】数字时代的影像保卫战:照片误删拯救全指南
  • 深度剖析八大排序算法
  • JVM_程序计数器的作用、特点、线程私有、本地方法的概述
  • 【Numpy核心编程攻略:Python数据处理、分析详解与科学计算】2.20 傅里叶变换:从时域到频域的算法实现
  • PAT甲级1052、Linked LIst Sorting
  • git error: invalid path
  • 优选算法合集————双指针(专题二)
  • Ubuntu下Tkinter绑定数字小键盘上的回车键(PySide6类似)
  • 使用arcpy列表函数
  • 基于联合概率密度与深度优化的反潜航空深弹命中概率模型研究摘要
  • 【PyQt】pyqt小案例实现简易文本编辑器
  • 二叉树03(数据结构初阶)
  • ComfyUI工作流 图像反推生成人像手办人像参考(SDXL版)
  • 【01】共识机制
  • sentinel的限流原理
  • ZOJ 1007 Numerical Summation of a Series
  • 『 C 』 `##` 在 C 语言宏定义中的作用解析
  • 独立成分分析 (ICA):用于信号分离或降维
  • 为什么会有函数调用参数带标签的写法?Swift函数调用的参数传递需要加前缀是否是冗余?函数调用?函数参数?
  • 实际操作 检测缺陷刀片
  • 使用Pygame制作“青蛙过河”游戏
  • BUU17 [RoarCTF 2019]Easy Calc1
  • 堆的实现——对的应用(堆排序)
  • 新生讲课——图和并查集
  • 基于深度学习的视觉检测小项目(十七) 用户管理后台的编程
  • 实战:利用百度站长平台加速网站收录
  • web-XSS-CTFHub
  • 【C++】P1957 口算练习题