蓝桥杯练习系统历届试题 带分数 dfs
100 可以表示为带分数的形式:100 = 3 + 69258 / 714。
还可以表示为:100 = 82 + 3546 / 197。
注意特征:带分数中,数字1~9分别出现且只出现一次(不包含0)。
类似这样的带分数,100 有 11 种表示法。
从标准输入读入一个正整数N (N<1000*1000)
程序输出该数字用数码1~9不重复不遗漏地组成带分数表示的全部种数。
注意:不要求输出每个表示,只统计有多少表示法!
// 纯纯的暴力 挂了。
#include <stdio.h>
#include <string.h>
#include <iostream>
using namespace std; int vis[], visall[]; bool check(int num) {
while(num) {
int temp = num % ;
if (vis[temp]) return false;
if (temp == ) return false;
vis[temp]++;
num /= ;
}
return true;
} bool checkAll() {
for (int i=; i<; ++i) {
if (vis[i] != ) return false;
}
return true;
} void copyNum(int a[], int b[]) {
for (int i=; i<; ++i) {
a[i] = b[i];
}
} int main() {
int n;
while(cin >> n) {
memset(vis, , sizeof(vis));
memset(visall, , sizeof(visall));
int ans = ; for (int l=; l<n; ++l) {
memset(vis, , sizeof(vis));
if (!check(l)) continue;
copyNum(visall, vis); for (int down=; down<; ++down) {
int up = (n-l) * down;
if (down > up) continue;
if (up % down) continue;
copyNum(vis, visall);
if (!check(down) || !check(up)) {
continue;
}
if (checkAll()) {
//cout << l << " " << down << " " << up << endl;
ans++;
}
}
} cout << ans << endl;
}
return ;
}
然后是优化。依然感觉dfs好神奇的说。
/*
刚才暴力的优化吧。
先遍历左边的数字,然后dfs搜分母对应的长度 和 数字。
*/ #include <stdio.h>
#include <string.h>
#include <iostream>
using namespace std; int lens, v, ans;
int vis[], visall[]; bool check(int num) {
int k = ;
while(num) {
int temp = num % ;
if (vis[temp]) return false;
vis[temp]++;
k++;
num /= ;
}
lens = -k; // 剩余可用数字的个数
return true;
} void copyVis() {
for (int i=; i<; ++i) {
visall[i] = vis[i];
}
} int judge(int up) { // fenmu
int k = ;
copyVis();
while(up) {
int temp = up % ;
if (visall[temp]) return -;
visall[temp] = ;
k++;
up /= ;
}
return k;
} void dfs(int len, int val) { // len fenzi
if (len > lens/) return;
if (judge(v*val) == lens-len) ans++;
for (int i=; i<; ++i) {
if (vis[i]) continue;
vis[i] = ;
dfs(len+, val*+i);
vis[i] = ;
}
} int main() {
int n;
while(cin >> n) {
ans = ;
for (int l=; l<n; ++l) {
memset(vis, , sizeof(vis));
vis[] = ;
if (!check(l)) continue;
v = n - l;
dfs(, ); // len fenmu
}
cout << ans << endl;
}
return ;
}
然后还有一种思路就是,对九个数字实现全排列,然后从八个空里找两个放+ 和 /。讲道理,这样的话,时间复杂度是10^6*8*7 不知道能不能过.....
蓝桥杯练习系统历届试题 带分数 dfs的更多相关文章
- 蓝桥杯练习系统历届试题 剪格子 dfs
问题描述 如下图所示,3 x 3 的格子中填写了一些整数. +--*--+--+|10* 1|52|+--****--+|20|30* 1|*******--+| 1| 2| 3|+--+--+--+ ...
- 蓝桥杯练习系统—基础练习 2n皇后问题
问题描述 给定一个n*n的棋盘,棋盘中有一些位置不能放皇后.现在要向棋盘中放入n个黑皇后和n个白皇后, 使任意的两个黑皇后都不在同一行.同一列或同一条对角线上,任意的两个白皇后都不在同一行. 同一列或 ...
- [18/12/3]蓝桥杯 练习系统 入门级别 Fibonacci数列求模问题 题解思路
前言略. 看到这个题目本来应该很高兴的,因为什么,因为太TM的基础了啊! 可是当你用常规方法尝试提交OJ时你会发现..hhh...运行超时..(开心地摇起了呆毛 //Fibonacci数列递归一般问题 ...
- 蓝桥杯之剪格子(经典dfs)
如下图所示,3 x 3 的格子中填写了一些整数. +--*--+--+ |10* 1|52| +--****--+ |20|30* 1| *******--+ | 1| 2| 3| +--+--+-- ...
- 蓝桥杯 地宫寻宝 带缓存的DFS
历届试题 地宫取宝 时间限制:1.0s 内存限制:256.0MB 问题描写叙述 X 国王有一个地宫宝库. 是 n x m 个格子的矩阵. 每一个格子放一件宝贝. 每一个宝贝贴着价 ...
- Java实现 蓝桥杯 历届试题 带分数
问题描述 100 可以表示为带分数的形式:100 = 3 + 69258 / 714. 还可以表示为:100 = 82 + 3546 / 197. 注意特征:带分数中,数字1~9分别出现且只出现一次( ...
- 算法笔记_197:历届试题 带分数(Java)
目录 1 问题描述 2 解决方案 1 问题描述 问题描述 100 可以表示为带分数的形式:100 = 3 + 69258 / 714. 还可以表示为:100 = 82 + 3546 / 197. ...
- 第六届蓝桥杯B组C++试题
1. 奖券数目 有些人很迷信数字,比如带"4"的数字,认为和"死"谐音,就觉得不吉利. 虽然这些说法纯属无稽之谈,但有时还要迎合大众的需求.某抽奖活动的奖券号 ...
- 36-2018 蓝桥杯Java B组试题及答案
1:第几天2000年的1月1日,是那一年的第1天.那么,2000年的5月4日,是那一年的第几天? 注意:需要提交的是一个整数,不要填写任何多余内容. 用excel算,答案125. 2.标题:方格计数 ...
随机推荐
- TA-Lib函数对照
Overlap Studies 重叠研究指标 BBANDS Bollinger Bands 布林带 DEMA Double Exponential Moving Average 双指数移动平均线 EM ...
- mysql 约束条件 not null与default
not null与default 是否可空,null表示空,非字符串not null - 不可空null - 可空 use db4: 默认值,创建列时可以指定默认值,当插入数据时如果未主动设置,则自动 ...
- android 第三方框架
1.视频:jcvideoplayer 2.圆角:cardview 3.圆形头像:circleimageview 4.加载网络图片:universalimageloader 5.网络请求:xutils ...
- 201-React顶级API
一.概述 React是React库的入口点.如果您从<script>标记加载React,则这些顶级API可在React全局中使用.如果你使用npm的ES6,你可以写:import Reac ...
- ftp文件上传和下载
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.N ...
- 20165324_mybash
20165324_mybash 实验要求 实验要求: 使用fork,exec,wait实现mybash 写出伪代码,产品代码和测试代码 发表知识理解,实现过程和问题解决的博客(包含代码托管链接) 背景 ...
- Amber安装并行
现在简单介绍一下amber12中安装openmpi并行的过程. 1. 下载openmpi版本在1.5-1.9之间的(openmpi-1.6.5.tar.bz2) 这是因为$AMBERHOME/Ambe ...
- 主从同步DNS(BIND)
看着别人搭建很简单,其实到自己做的时候需要考虑更多的问题. 1.环境 1)操作系统最好一样,配置一样 2)关闭防火墙,selinux,时间要同步(我就是用的纽约的时区,同步中国的时间,虽然时间是相同的 ...
- Java文件IO流的操作总结
Java中的IO操作涉及到的概念及相关类很多,很容易弄混,今天特来整理总结一下,并附上一份完整的文件操作的代码. 概念解析 读和写 流就是管道,向管道里面写数据用输出流:write 从管道里面读数据, ...
- vuex的一个坑
1 error in callback for watcher "function (){ return this._data.$$state }" 用深拷贝解决 2 接口依赖: ...