1.   数字分解

【问题描述】

任何一个大于1的自然数n,总可以拆分成若干个小于n的自然数之和,当n等于5时有6种拆分方法:

5=1+1+1+1+1

5=1+1+1+2

5=1+1+3

5=1+2+2

5=1+4

5=2+3

输入:一行包含一个正整数n(1<n<10)。

输出:先将拆分方案输出,然后再输出拆分的方案数。

【输入样例】

5

【输出样例】

5=1+1+1+1+1

5=1+1+1+2

5=1+1+3

5=1+2+2

5=1+4

5=2+3

total=6

#include <iostream>
using namespace std;
int a[] = {},n,total; //输出函数
void print(int t) { //拆成t项
cout << n << "=";
for(int i = ; i <= t-; i++) {
cout << a[i] << "+";
}
cout << a[t] << endl;
total++;
} void find(int m,int t) {
for(int i = a[t-]; i<=m; i++) {
if(i < n) {
a[t] = i; //保存当前拆分的i
m-=i;
if(m ==) { //拆分结束,输出结果
print(t);
} else {
find(m,t+);
}
m+=i; //回溯:加上拆分的数,以便产生所有可能的拆分
}
}
}
int main() {
cin >> n;
find(n,);
cout << "total=" <<total << endl;
return ;
}

2.放苹果

【问题描述】

把M个同样的苹果放在N个同样的盘子里,允许有的盘子空着不放,问共有多少种不同的分法?(用K表示)5,1,1和1,5,1 是同一种分法。

输入:第一行是测试数据的数目t(0 <= t <= 20)。以下每行均包含二个整数M和N,以空格分开。1<=M,N<=10。

输出:对输入的每组数据M和N,用一行输出相应的K。

【输入样例】

1

7 3

【输出样例】

8

/*
m个苹果放在n个盘子中,那么定义函数为apple(m,n): 1.m=0,没有苹果,那么只有一种放法,即apple(0,n)=1 2.n=1,只有一个盘中,不论有或者无苹果,那么只有一种放法,apple(m,1)=1 3.n>m,和m个苹果放在m个盘子中是一样的,即apple(m,n)=apple(m,m) 4.m>=n,这时分为两种情况,一是所有盘子都有苹果,二是不是所有盘子都有苹果。
不是所有盘子都有苹果和至少有一个盘子空着是一样的,即=apple(m,n-1)。所
有盘子都有苹果,也就是至少每个盘子有一个苹果,m个苹果中的n个放在n个盘子中,
剩下的m-n个苹果,这和m-n个苹果放在n个盘子中是是一样的,即=apple(m-n, n)。
这时,apple(m,n)=apple(m-n, n)+apple(m,n-1)。
*/
#include<iostream>
using namespace std;
int apple(int m,int n) { //m个苹果放到n个盘子里
if(m < || n <){
return ;
}
//判断只有一个方法放苹果的情况
if(m== || n==){
return ;
}
//否则判断苹果数是否少于盘子数,如果少,那么肯定有n-m个空盘子
//所以只要做把m个苹果放到m个盘子里
else if(m<n) {
return apple(m,m);
}
//m>=n的情况 :
//所有的盘子都有苹果,即只要把m-n个苹果放到n个盘子里
//不是所有盘子都有苹果和至少有一个盘子空着是一样的,即=apple(m,n-1)
else {
return apple(m-n,n)+apple(m,n-);
} }
int main() {
int t;
cin>>t;
while(t--) {
int m,n;
cin>>m>>n;
cout<<apple(m,n)<<endl;
}
}

1.全排列

【问题描述】

输入一个数字N(1<N<10),输出所有使用1到N数字组成的N位数(每个数字只能使用一次)。

【样例输入】

3

【样例输出】

123

132

213

231

312

321

#include <iostream>
using namespace std;
int a[],book[],n; //站在第step个盒子面前
void dfs(int step){
int i;
if(step == n+){
//输出一种全排列
for(i = ;i<=n;i++){
cout << a[i];
}
cout << endl;
return; //返回之前的一步,最近一次调用dfs函数的地方
} //站在第step个盒子面前, 遍历1到n一一去尝试
for(i = ;i <= n;i++){
//判断该数字是否还未被使用
if(book[i] == ){
a[step] = i;
book[i] = ;//表示已被使用 //接下里走到step+1的盒子面前,做同样的操作
dfs(step+);
book[i]=;//一定要将刚才尝试的数字收回,才能进行下一次的尝试
}
} return;
}
int main(){
cin >> n;
dfs();
return ;
}

2.分为互质组

【问题描述】

给定n个正整数,将他们分组,使得每组中任意两个数互质。至少要分成多少个组?

输入:第一行是一个正整数n,1<=n<=10;第二行是n个不大于10000的正整数。

输出:一个正整数,即最少需要的组数。

【输入样例】

6

14 20 33 117 143 175

【输出样例】

3

#include <iostream>
using namespace std;
int a[],b[],n;
int ans;
//定义gcd函数求两个数的最大公约数
int gcd(int a,int b) {
if(b==) {
return a;
} else {
return gcd(b,a%b);
}
}
void dfs(int x,int y) { //x:第几个数 y:已有多少组
//递归终止条件
if(x>n) {
ans = y;
return;
}
bool flag = false;
//判断当前值是否是属于已有组
for(int i = ; i <=y; i++) {
bool pd = true;
for(int j = ; j < x; j++) {
//第j个元素属于第i组,并且第x个元素与第j个元素不是互为质数,则a[x]不属于第i组
if(b[j] == i && gcd(a[x],a[j]) != ) {
pd = false;
break;
}
}
if(pd == true) { //第x个元素与第i组的所有元素都互为质数
flag = true;
//第x个元素属于第i组
b[x] = i;
//接着判断下一个元素(第x+1个元素)是否属于已有的y组
dfs(x+,y);
//将b[x]重新赋值为0
b[x]=;
}
}
if(flag == false) {
//如果当前值不属于已有的任何一组 需要新开一个组别
//第x个元素属于第y+1组
b[x] = y+;
//接着判断下一个元素(第x+1个元素)是否属于已有的y+1组
dfs(x+,y+);
b[x] = ;
}
}
int main() {
cin >> n;
for(int i = ; i <=n; i++) {
cin >> a[i];
}
//初始化b数组,第1个元素属于第1组
b[] = ;
dfs(,);
cout << ans << endl;
return ;
}

noip第22课作业的更多相关文章

  1. noip第5课作业

    1.     计算税收 [问题描述] 对某产品征收税金,在产值1万元以上收税5%:在1万元以下但在5000元或者以上的征收税3%:在5000元以下但在1000元或以上征收税2%:1000元以下的免收税 ...

  2. noip第22课资料

  3. noip第34课作业

    1.    信息加密 [问题描述] 在传递信息的过程中,为了加密,有时需要按一定规则将文本转换成密文发送出去.有一种加密规则是这样的:1. 对于字母字符,将其转换成其后的第3个字母.例如:A→D,a→ ...

  4. noip第33课作业

    1.    排座椅 [问题描述] 上课的时候总会有一些同学和前后左右的人交头接耳,这是令小学班主任十分头疼的一件事情.不过,班主任小雪发现了一些有趣的现象,当同学们的座次确定下来之后,只有有限的D对同 ...

  5. noip第29课作业

    1.   钢条切割 [问题描述] 一家公司购买长钢条,将其切割成短钢条出售,切割本身没有成本,长度为i的短钢条的价格为Pi.那给定一段长度为n的钢条和一个价格表Pi,求钢条的切割方案使得收益Rn最大. ...

  6. noip第28课作业

    分段数列 [问题描述] 对于给定的一个长度为N的正整数数列A[i],现要将其分成连续的若干段,并且每段和不超过M(可以等于M),问最少能将其分成多少段使得满足要求. 输入格式: 输入第1行包含两个正整 ...

  7. noip第27课作业

    1. 繁忙的都市 [问题描述] 城市C是一个非常繁忙的大都市,城市中的道路十分的拥挤,于是市长决定对其中的道路进行改造.城市C的道路是这样分布的:城市中有n个交叉路口,有些交叉路口之间有道路相连,两个 ...

  8. noip第26课作业

    1.    信使 [问题描述] 战争时期,前线有n个哨所,每个哨所可能会与其他若干个哨所之间有通信联系.信使负责在哨所之间传递信息,当然,这是要花费一定时间的(以天为单位).指挥部设在第一个哨所.当指 ...

  9. noip第25课作业

    1.   求一个有向图所有顶点入度的和 输入有向图的顶点个数,边数以及各顶点之间的关联情况,要求求出这个有向图的所有顶点入度的总和. [输入格式] 第1行:2个空格分开的整数n(2<=n< ...

随机推荐

  1. c#networkcomms protobuf-net 文件加载出现问题

    服务器端里添加客户管理添加了些功能, 客户端私活连不上了,老程序没问题, 在服务器端程序里边也接受不到事件,客户端就提示链接中断了, 在客户端里边查了 链接中断是客户端上做的,当传回的包为0 事,程序 ...

  2. sharpsvn 继续,解决文件locked 问题,

    方法中少个方法就会出现一些问题. 比如进行了断线测试,结果再操作时就出现了文件被锁的情况,最终查了官网的论坛,才得以解决 How to unlock if the working copy is lo ...

  3. Oracle_PL/SQL(7) 集合

    pl/sql集合处理单行单列数据,可以使用标量变量:处理单行多列的数据,可以使用pl/sql记录(%rowtype,record):处理单列多行数据,可以使用pl/sql集合. pl/sql集合类型是 ...

  4. Python 字符串(count)

    字符串 count:(python中的count()函数,从字面上可以知道,他具有统计功能) Python count() 方法用于统计字符串里某个字符出现的次数.可选参数为在字符串搜索的开始与结束位 ...

  5. PAT 1039 到底买不买(20)(20 分)

    1039 到底买不买(20)(20 分) 小红想买些珠子做一串自己喜欢的珠串.卖珠子的摊主有很多串五颜六色的珠串,但是不肯把任何一串拆散了卖.于是小红要你帮忙判断一下,某串珠子里是否包含了全部自己想要 ...

  6. hadoop 启动的时候datanode报错 Problem connecting to server

    刚配置好的hadoop,namenode可以正常开启,但是datanode却不停的报错,并且不能正常启动: 2014-05-04 10:43:33,970 WARNorg.apache.hadoop. ...

  7. [Robot Framework] 怎么做数学运算?

    运用BuiltIn里面的Set Variable

  8. Python之路(第二十五篇) 面向对象初级:反射、内置方法

    [TOC] 一.反射 反射的概念是由Smith在1982年首次提出的,主要是指程序可以访问.检测和修改它本身状态或行为的一种能力(自省).这一概念的提出很快引发了计算机科学领域关于应用反射性的研究.它 ...

  9. Null value was assigned to a property of primitive type setter of cn.itcast.oa.domain.Forum.topicCount

    [引用http://m.blog.csdn.net/blog/u013998070/41087351] Null value was assigned to a property of primiti ...

  10. [转]Firefox+Burpsuite抓包配置(可抓取https)

    0x00 以前一直用的是火狐的autoproxy代理插件配合burpsuite抓包 但是最近经常碰到开了代理却抓不到包的情况 就换了Chrome的SwitchyOmega插件抓包 但是火狐不能抓包的问 ...