书本转移

来源:互联网 发布:ubuntu虚拟机安装教程 编辑:程序博客网 时间:2024/04/27 17:10

小强有 3 个箱子 A,B,C 用来装书,所有的书(一共n本)都按序号由小到大的顺序堆在 A上,现在他想把所有的书全都放到 C 里面去。每次他从 A 书架拿 a 本书(不够就全拿完)到 B,A 箱子翻转,然后从 B 拿 b 本书(不够就全拿完)到 C,B 箱子翻转。然后重复操作,直到所有书都到了 C,求最后的C 里面书的顺序,详细见样例。 输入描述: 输入由多组数据构成,每组数据占一行,3 个数,n(1<=n<=10^5),a(1<=a<=10^9) , b(1<=b<=10^9),含义见题目表述。以文件结尾。 输出描述: 每组数据输出一行,首先输出数据组数,然后输出 n 个数,C 中书的排列。


输入输出没有按照要求进行,主要过程经过简单测试


// bookmove.cpp : 定义控制台应用程序的入口点。//#include "stdafx.h"int _tmain(int argc, _TCHAR* argv[]){long n = 10;long a = 1;long b = 1;printf("input n,a,b:");scanf("%d%d%d",&n,&a,&b);long cstart = 0;  //C 书本开始序号char aover = 0; //A 是否全部拿完 1完 0非char bover = 0; //B 是否全部拿完 1完 0非if(n <= a){aover = 1;}if (aover){//a全部拿完if (n <= b){bover = 1;}}else{if (a <= b){bover = 1;}}//对于aover bover讨论if (aover){if (bover){cstart = 1;} else{cstart = n - b + 1;}}else{if (bover){cstart = n - a + 1;} else{cstart = n - b + 1;}}for (long i = cstart;i <= n;i++){printf("%d\t",i);}printf("\n");getchar();return 0;}





0 0
原创粉丝点击