蓝桥杯 带分数 DFS应用
100 可以表示为带分数的形式:100 = 3 + 69258 / 714。
还可以表示为:100 = 82 + 3546 / 197。
注意特征:带分数中,数字1~9分别出现且只出现一次(不包含0)。
类似这样的带分数,100 有 11 种表示法。
从标准输入读入一个正整数N (N<1000*1000)
程序输出该数字用数码1~9不重复不遗漏地组成带分数表示的全部种数。
注意:不要求输出每个表示,只统计有多少表示法!
#include <iostream>
#include <algorithm>
#include <cstdio>
using namespace std; int num[] = {, , , , , , , , },
N, ans; int getSum(int lh, int rh)
{
int sum = ;
for (int i = lh; i <= rh; i++)
{
sum = sum * + num[i];
}
return sum;
} void check()
{
for (int i = ; i < ; i++)
{
int a = getSum(, i);
if (a > N) continue;
for (int j = i + ; j < ; j++)
{
int b = getSum(i + , j);
int c = getSum(j + , );
if (b >= c && b % c == && (a + b/c == N)) {
ans++;
}
}
}
} void solve()
{
cin >> N;
do {
check();
} while(next_permutation(num, num + ));
printf("%d\n", ans);
} int main()
{
solve();
return ;
}
//法二
#include <algorithm>
#include <cstring>
#include <queue>
#define INF 0x3f3f3f3f
#define MAXN 100005
#define Mod 10001
using namespace std;
int vis[], n , ans;
int num[]; int getSum(int lh, int rh)
{
int sum = ;
for (int i = lh; i <= rh; i++) {
sum = sum * + num[i];
}
return sum;
} void check()
{
for (int i = ; i <= ; i++) {
int a = getSum(, i);
if (a > n) continue;
for (int j = i + ; j < ; j++) {
int b = getSum(i + , j); //[i+1, j]
int c = getSum(j + , ); //[j+1, 9]
if (b >= c && b % c == && a + b/c == n) {
ans++;
}
}
}
} void dfs(int step)
{
if (step == ) {
check();
}
else {
for (int i = ; i <= ; i++) {
if (!vis[i]) {
num[step] = i;
vis[i] = ;
dfs(step + );
vis[i] = ;
}
}
} } int main()
{
scanf("%d", &n);
ans = ;
memset(vis, , sizeof(vis));
dfs();
printf("%d\n", ans);
return ;
}
#include <iostream>
#include <algorithm>
#include <cstring>
using namespace std; int a[] = {, , , , , , , , , };
int b, c;
int d; void solve()
{
do {
b = a[]* + a[]* + a[]* + a[];
c = a[]* + a[]* + a[]* + a[];
d = a[]* + a[]* + a[]* + a[]* + a[];
// if (b + c == d) {
// cout << b << " + " << c << " = " << d << endl;
// }
} while (next_permutation(a, a + ));
} int main()
{
solve();
return ;
}
//发现好多蓝桥杯省赛的题目 都可以用 next_permutation()轻松解决..
//还有之前整理的一个题目: http://www.cnblogs.com/douzujun/p/6669303.html
蓝桥杯 带分数 DFS应用的更多相关文章
- 蓝桥杯 - 带分数 (DFS)
历届试题 带分数 时间限制:1.0s 内存限制:256.0MB 问题描写叙述 100 能够表示为带分数的形式:100 = 3 + 69258 / 714. 还能够表示为:10 ...
- java实现第四届蓝桥杯带分数
带分数 题目描述 100 可以表示为带分数的形式:100 = 3 + 69258 / 714 还可以表示为:100 = 82 + 3546 / 197 注意特征:带分数中,数字1~9分别出现且只出现一 ...
- 蓝桥杯 全球变暖(dfs)
标题:全球变暖 [题目描述]你有一张某海域NxN像素的照片,"."表示海洋."#"表示陆地,如下所示: 其中"上下左右"四个方向上连在一起的 ...
- POJ 2676 - Sudoku - [蓝桥杯 数独][DFS]
题目链接:http://poj.org/problem?id=2676 Time Limit: 2000MS Memory Limit: 65536K Description Sudoku is a ...
- 蓝桥杯PREV-12(dfs&割点)
题目链接:http://lx.lanqiao.cn/problem.page?gpid=T35 题意:中文题诶- 思路:dfs 假设star 和 end之间总路径数目为ans, 那么若经过路径上某点到 ...
- 蓝桥杯---数独(模拟 || dfs)
[编程题](满分33分) "数独"是当下炙手可热的智力游戏.一般认为它的起源是"拉丁方块",是大数 学家欧拉于1783年发明的. 如图[1.jpg]所示:6x6 ...
- 蓝桥杯---剪格子(DFS&BFS)(小总结)
问题描述 如下图所示,3 x 3 的格子中填写了一些整数. +--*--+--+ |10* 1|52| +--****--+ |20|30* 1| *******--+ | 1| 2| 3| +--+ ...
- 蓝桥杯之大臣的旅费(两次dfs)
Description 很久以前,T王国空前繁荣.为了更好地管理国家,王国修建了大量的快速路,用于连接首都和王国内的各大城市. 为节省经费,T国的大臣们经过思考,制定了一套优秀的修建方案,使得任何一个 ...
- 蓝桥杯之剪格子(经典dfs)
如下图所示,3 x 3 的格子中填写了一些整数. +--*--+--+ |10* 1|52| +--****--+ |20|30* 1| *******--+ | 1| 2| 3| +--+--+-- ...
随机推荐
- Html_div圆角
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- mybati缓存机制之一级缓存
在月黑风高的某天夜晚,boss chen语重心长的发条了消息给小草说:“小草啊,是时候写写博客来记录平常自己积累的东西了......”.小草一听,平常没有写博客的习惯,在平常开发中只是用笔记记录自 ...
- Linux DDos防御
今天要说的就是一款能够自动屏蔽DDOS攻击者IP的软件:DDoS deflate. DDoS deflate介绍 DDoS deflate是一款免费的用来防御和减轻DDoS攻击的脚本.它通过netst ...
- mac osx 初次使用PHP环境搭建
非常简单,一共2个步骤: Step1: 启动Apache mac osx 系统默认安装Apache服务. 首先打开terminal,输入: sudo apachectl start 如果需要输入密码, ...
- 用C语言编程自动生成四则运算
#include<stdio.h>#include<stdlib.h>#include <time.h>#define N 30main(){ int a,b,k, ...
- hybrid浅记
目前首次接触hybrid项目,故根据翻阅了解后,浅记对它的认识. hybrid是携程推出的一个项目框架,其优点是:跨平台.开发效率高.开发成本相对较低,其不足是:体验不如Native hybrid设计 ...
- Linux命令(二十) 显示系统内存状态 free
一.命令简介 free 命令会显示内存的使用情况,包括实体内存,虚拟的交换文件内存.共享内存区段,以及系统核心使用的缓冲区等. 二.参数说明 -b 以Byte为单位显示内存使用情况 -K 以KB为单位 ...
- [From WIKI] IBM Z
IBM zEnterprise System From Wikipedia, the free encyclopedia Jump to navigationJump to search Hi ...
- laravel 处理自定错误页面,如404,500,501,502,503,504等等
laravel 5.0 版本下,修改pp/Exceptions/Handler.phppublic function render($request, Exception $e) { if ($e i ...
- 一本通1639Biorhythms
1639:Biorhythms 时间限制: 1000 ms 内存限制: 524288 KB [题目描述] 原题来自:POJ 1006 人生来就有三个生理周期,分别为体力.感情和智力周期 ...