C语言 百炼成钢16
//题目46:海滩上有一堆桃子,五只猴子来分。第一只猴子把这堆桃子凭据分为五份,多了一个,这只
//猴子把多的一个扔入海中,拿走了一份。第二只猴子把剩下的桃子又平均分成五份,又多了
//一个,它同样把多的一个扔入海中,拿走了一份,第三、第四、第五只猴子都是这样做的,
//问海滩上原来最少有多少个桃子? #include<stdio.h>
#include<stdlib.h> //分析:最少有多少个桃子,说明是满足条件的最小数;假设有X个桃子,第一个猴子的桃子数量是(X-1)/5,
//第二只猴子的数量是(第一个猴子的桃子数量的4倍-1)/5 即(4*f(1)-1)/5=f(2)====> f(1)=(5*f(2)+1)/4
//f(n)=(5*f(n+1)+1)/4 int i = ;
int t = ; int Peach(int n){
if (n == )
{
i++;
return i;
}
else{
t = * Peach(n + ) + ;
do{
t = * Peach(n + ) + ;
} while (t % != );
//如果不是4的倍数 那么第n个猴子有的桃子数量不是整数,
return t / ;
}
} void main(){ printf("海滩上原来最少有%d个桃子\n", *Peach()+);
system("pause");
}

//题目47:尼科彻斯定理证明
//任何一个整数的立方都可以写成一串连续奇数的和 //思路:一串连续奇数,可以从1+3+...,当和>整数的立方的时候,可以减去第一个奇数1,继续判断和是否>整数的立方
//如果仍然大于整数的立方,再减去第二个奇数,一直继续直到和小于整数的立方时,末尾再加上 最后的奇数+2
#define _CRT_SECURE_NO_WARNINGS #include<stdio.h>
#include<stdlib.h>
#include<math.h>
#include<assert.h> void main(){
int tnum = ;
int num = ;
int tsun = ;
int index = ;
int k = ;
int i = ;
printf("请输入一个整数\n");
scanf("%d", &tnum);
//断言
assert(tnum != );
num = tnum*tnum*tnum;
while (){
tsun += i;
i += ;
if (i>num)
{
break;
}
//当和大于整数的立方时,进行减少奇数操作
if (tsun>num)
{
index = tsun;
k = ;
//从1开始,不断减去前面的奇数
while (index > num){
index -= k;
k = k + ;
}
//如果结果不等于num,说明不是连续的奇数,需要在后面继续追加一个奇数
if (index != num)
{
continue;
}
else{
//打印结果
for (int m = k; m+ <=i; m=m+)
{
if (m+>=i)
{
printf("%d", m);
}
else{
printf("%d+", m);
}
}
break;
}
}
//当和等于整数的立方时
else if (tsun==num)
{
//打印结果
for (int m = ; m+ <=i; m = m + )
{
if (m + >= i)
{
printf("%d", m);
}
else{
printf("%d+", m);
}
}
break;
}
}
printf("=%d\n",num); system("pause");
}

//题目48:父亲拿出2520个苹果,按照写在纸上的数量分给6个兄弟,每个人分到的苹果数量都不相同
//他说:老大,把你分到的苹果的1/8给老二,老二拿到后,连同原来的苹果分1/7给老三,老三拿到后,
//连同原来的苹果分1/6给老四,以此类推,最后老六拿到后,连同原来的苹果分1/7给老大,
//这样你们每个人分到的苹果数量就一样多了。求出原来各兄弟分得多少个苹果。 #include<stdio.h>
#include<stdlib.h> //思路:从老二开始分析:老二没分苹果时苹果的数量 = 老大原有的苹果数量*(1/8) + 老二原有的苹果数量
//就老二比较特殊,后面的就比较规律
//老三没分苹果时苹果的数量 = 老二没分苹果时苹果的数量*(1/7) + 老三原有的苹果数量
//按照此规律,最后6个人苹果的数量相等 都是420个
//那么 老二没分苹果时苹果的数量*(6/7) = 420,由此可以求出 老二到老六没分苹果时苹果的数量
//老大的最终苹果数量420 = 老六没分苹果时苹果的数量*(1/3) + 老大原有的苹果数量*(7/8)
//由此可以求出老大原有的苹果数量,进而可以求出老二原有的苹果数量 void main(){
//x[6]表示原来的苹果,y[6]表示拿到苹果不分给其他人的苹果数量
int x[] = { }, y[] = {};
//根据分析 老二拿到的苹果(不分给老三)=老大以前的苹果*(1/8)+老二原来的苹果
//即;老二原来的苹果=老二拿到的苹果(不分给老三)-老大以前的苹果*(1/8) for (int i = ; i < ; i++)
{
y[i] = * ( - i) / ( - i);
}
//获取老大原来的苹果数
//420=老六苹果数(不分给别人)*1/3+老大原来苹果数(7/8)
//老大原来苹果数=(420-老六苹果数(不分给别人)*1/3)*8/7
//y[0]=x[0]的解释 老大拿到苹果不分给其他人的苹果数量 就是老大原来的苹果数量
y[]=x[] = ( - y[] * / ) * / ;
for (int i = ; i < ; i++)
{
//y[i - 1] / (9-i) 把老二没分苹果的数量*(1/7)+老三原有的数量 ==老三现在没分苹果的数量
//老三原有的数量==老三现在没分苹果的数量 - 老二没分苹果的数量*(1/7)
x[i] = y[i] - y[i - ] / (-i);
}
int sun = ;
for (int i = ; i < ; i++)
{
sun += x[i];
printf("第%d个兄弟的原来的苹果数量%d\n",i+,x[i]);
}
printf("总数量是%d\n",sun);
system("pause");
}

C语言 百炼成钢16的更多相关文章
- C语言基础(16)-指针
一.指针的相关概念 1.1 指针变量 指针是一个变量,存放的是一个地址,该地址指向一块内存空间. 例: ; int *p = &a; // 定义一个指针变量p,&符号可以取得一个变量在 ...
- C语言 百炼成钢1
//题目:有1.2.3.4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少? #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> ...
- C语言 百炼成钢19
/* 题目55: 有一个字符串符合以下特征(”abcdef,acccd,eeee,aaaa,e3eeeee,sssss,";),要求写一个函数(接口),输出以下结果 1) 以逗号分割字符串, ...
- C语言 百炼成钢6
//题目16:输入两个正整数m和n,求其最大公约数和最小公倍数. #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include< ...
- C程序设计语言练习题1-6
练习1-6 验证表达式getchar() != EOF的值是0还是1. 代码如下: #include <stdio.h> // 包含标准库的信息. int main() // 定义名为ma ...
- 用纯c语言完成16位模式下的引导程序
gcc在16位模式下做引导程序遇到的问题太多了,不过费了很大劲逐一解决了. 自己的小demo也从一开始的1个扇区增加到了20几个扇区. 先上图做个标记,后面有时间再上代码.
- Java入门 - 语言基础 - 16.数组
原文地址:http://www.work100.net/training/java-array.html 更多教程:光束云 - 免费课程 数组 序号 文内章节 视频 1 概述 2 声明数组变量 3 创 ...
- C语言 百炼成钢3
//题目7:用*号输出空心菱形图案 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<stdlib.h> # ...
- C语言 百炼成钢2
//题目4:输入某年某月某日,判断这一天是这一年的第几天? #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<st ...
随机推荐
- 关于报malformed or corrupted AST file: 'Unable to load module 的错~
今天早上 一运行程序 居然报错,我都惊呆了,昨天明明好好的-但是百度是强大的- 报错内容: malformed or corrupted AST file: 'Unable to load modul ...
- java 之 file类的一些方法
File类: File类是java.io包下代表与平台无关的文件和目录,也就是说,如果希望在程序中操作文件和目录,都可以通过File类来完成.但是File不能访问文件内容本身. 访问文件和目录: 1. ...
- java集合 之 Collection和Iterator接口
Collection是List,Queue和Set接口的父接口,该接口里定义的方法即可用于操作Set集合,也可以用于List和Queue集合.Collection接口里定义了如下操作元素的方法. bo ...
- UVa 112 - Tree Summing(树的各路径求和,递归)
题目来源:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=3&pa ...
- DP大作战——多重背包
题目描述 在之前的上机中,零崎已经出过了01背包和完全背包,也介绍了使用-1初始化容量限定背包必须装满这种小技巧,接下来的背包问题相对有些难度,可以说是01背包和完全背包的进阶问题. 多重背包:物品可 ...
- 测试mysql的sql语句预编译效果
玩Oracle的都比较关注shared pool,特别是library cache,在使用了绑定变量(预编译sql)之后确实能得到很大的性能提升.现在在转Mysql之后特别是innodb很多东西都还能 ...
- 读书笔记——Windows环境下32位汇编语言程序设计(13)关于EXCEPTION_DEBUG_INFO结构体
在动手自己尝试编写书上第13章的例子Patch3时,遇到了一个结构体EXCEPTION_DEBUG_INFO. 这个结构体在MASM的windows.inc中的定义和MSDN中的定义不一样. (我使用 ...
- MyEclipse中SVN的常见的使用方法
本次主要内容: 一 .导入项目 (Checkout).从svn资源库检出 二 .更新 (Update) 三.锁(对要修改的文件加锁,防止文件冲突) 四.提交(项目修改后的提交) 五.解锁 六.查看历史 ...
- dubbo学习之服务提供者
1.简介 这里主要记录如何搭建一个spring框架,提供一个dubbo服务,包括详细的步骤. 2.详细步骤 2.1 项目目录结构 2.2 创建maven项目 new --> Web Projec ...
- hdu-1789-Doing Homework again
/* Doing Homework again Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Oth ...