1.普通版

第一眼看到这个题,我脑海里就是,“我们是不是在哪里见过~”,去年大一刚学C语言的时候写过一个类似的题目,写了九重循环。。。。就像这样(在洛谷题解里看到一位兄台写的。。。。超长警告,慎重点开

#include <stdio.h>
#include <cstdlib>
int main()
{
int i[];
for (i[] = ; i[] <= ; i[]++)
{
for (i[] = ; i[] <= ; i[]++)
{
int p1=;
if (i[] == i[]) p1 = ;
if (p1 != ) {
for (i[] = ; i[] <= ; i[]++)
{
int p2=;
for (int j2 = ; j2 < ; j2++) if (i[] == i[j2]) p2 = ;
if (p2 != ) {
for (i[] = ; i[] <= ; i[]++)
{
int p3=;
for (int j3 = ; j3 < ; j3++) if (i[] == i[j3]) p3 = ;
if (p3 != ) {
for (i[] = ; i[] <= ; i[]++)
{
int p4=;
for (int j4 = ; j4 < ; j4++) if (i[] == i[j4]) p4 = ;
if (p4 != ) {
for (i[] = ; i[] <= ; i[]++)
{
int p5=;
for (int j5 = ; j5 < ; j5++) if (i[] == i[j5]) p5 = ;
if (p5 != ) {
for (i[] = ; i[] <= ; i[]++)
{
int p6=;
for (int j6 = ; j6 < ; j6++) if (i[] == i[j6]) p6 = ;
if (p6 != ) {
for (i[] = ; i[] <= ; i[]++)
{
int p7=;
for (int j7 = ; j7 < ; j7++) if (i[] == i[j7]) p7 = ;
if (p7 != ) {
for (i[] = ; i[] <= ; i[]++)
{
int p8=;
for (int j8 = ; j8 < ; j8++) if (i[] == i[j8]) p8 = ;
if (p8 != ) {
//printf("%d %d %d %d %d %d %d %d %d\n", i[0], i[1], i[2], i[3], i[4], i[5], i[6], i[7], i[8]);
int a = * i[] + * i[] + i[];
int b = * i[] + * i[] + i[];
int c = * i[] + * i[] + i[];
double d1 = double(a) / b;
double d2 = double(c) / b;
if (d1 == 0.5 && d2 == 1.5)
{
printf("%d %d %d\n", a, b, c);
//system("pause");
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
system("pause");
return ;
}

假设这三个数是 x : y : z  = 1 : 2 : 3,那么z最大可以为987,那么x最大到329(其实比329还要小几个数,因为数字重复了,懒得去抠了),那就好办了,x 从123循环到329,判重就完事了。

#include <iostream>
#include <string.h>
using namespace std;
int a[];
//判重,且不能带0
int IsRepeat(int x) {
memset(a, , sizeof(int) * );
while (x) {
int t = ++a[x % ];
if (t == || a[] == )
return ;
x /= ;
}
return ;
}
int IsRepeat2(int x,int y,int z) {
memset(a, , sizeof(int) * );
while (x) {
a[x % ]++; a[y % ]++; a[z % ]++;
if (a[] > ) return ;
x /= ; y /= ; z /= ;
}
for (int i = ; i < ; i++)
if (a[i] > ) return ;
return ;
}
int main() {
//x,y,z 1:2:3,z最大可以为987,那么1最大到329
for (int x = ; x <= ; x++) {
if (IsRepeat(x)) {
continue;
}
//如果x不重复,y,z 也不会重复
int y = x * ; int z = x * ;
if (!IsRepeat2(x, y, z)) {
cout << x << " " << y << " " << z << endl;
}
}
return ;
}

2.升级版

就是把原来的比例从1:2:3,变成了A:B:C。

思路还是差不多,中间continue判断,写的好像有点乱,但是确实不能少。

#include <iostream>
using namespace std;
bool IsRepeat(int x) {
int a[] = { };
while (x) {
int t = a[x % ]++;
if (t == || a[] == )
return true;
x /= ;
}
return false;
}
bool IsRepeat3(int x, int y, int z) {
int a[] = { };
while (x) {
a[x % ]++; a[y % ]++; a[z % ]++;
if (a[] > ) return true;
x /= ; y /= ; z /= ;
}
for (int i = ; i < ; i++)
if (a[i] > ) return true;
return false;
}
int main() {
int A, B, C, flag = ;
cin >> A >> B >> C;
for (int i = ; i < ; i++) {
int j, k;
if (IsRepeat(i))continue; if (i * B % A == ) j = i * B / A;
else continue; if (j > )continue; if (j*C%B == ) {
k = j * C / B;
if (k > || IsRepeat3(i, j, k))continue;
flag = ;
cout << i << " " << j << " " << k << endl;
}
}
if (!flag)cout << "No!!!" << endl;
return ;
}

随手练——洛谷-P1008 / P1618 三连击(暴力搜索)的更多相关文章

  1. 随手练——洛谷-P1151(枚举与暴力搜索)

    枚举 #include <iostream> using namespace std; int main() { ; cin >> k; ; i < ; i++) { ) ...

  2. 随手练——洛谷-P1002 过河卒(动态规划入门)

    题目链接:https://www.luogu.org/problemnew/show/P1002 题目还算良心,提醒了结果可能很大,确实爆了int范围, 这是一开始写的版本,用递归做的,先给地图做标记 ...

  3. 随手练—— 洛谷-P2945 Sand Castle(贪心)

    题目链接:https://www.luogu.org/problemnew/show/P2945 (原题 USACO) 要求钱最少,就是试着让M和B的离散程度最小(我自己脑补的,就是总体更接近,我不知 ...

  4. 洛谷 p1008三连击

    洛谷 p1008三连击 题目背景 本题为提交答案题,您可以写程序或手算在本机上算出答案后,直接提交答案文本,也可提交答案生成程序. 题目描述 将1,2, ⋯,9共99个数分成3组,分别组成3个三位数, ...

  5. 【题解】洛谷P1120 小木棍(搜索+剪枝+卡常)

    洛谷P1120:https://www.luogu.org/problemnew/show/P1120 思路 明显是搜索题嘛 但是这数据增强不是一星半点呐 我们需要N多的剪枝 PS:需要先删去超出50 ...

  6. 【题解】洛谷P1731 [NOI1999] 生日蛋糕(搜索+剪枝)

    洛谷P1731:https://www.luogu.org/problemnew/show/P1731 思路 三重剪枝 当前表面积+下一层表面积如果超过最优值就退出 当前体积+下一层体积如果超过总体积 ...

  7. 和小哥哥一起刷洛谷(5) 图论之深度优先搜索DFS

    关于dfs dfs伪代码: void dfs(s){ for(int i=0;i<s的出度;i++){ if(used[i]为真) continue; used[i]=1; dfs(i); } ...

  8. 和小哥哥一起刷洛谷(4) 图论之广度优先搜索BFS

    关于bfs: 你怎么会连这个都不知道!!!自己好好谷歌一下!!!(其实我也刚学) bfs伪代码: while(队列非空){ 取出队首元素u; 弹出队首元素; u染色为黑色; for(int i=0;i ...

  9. 洛谷p1008 三连击

    https://www.luogu.org/problemnew/show/P1008 题目描述 将1,2,3,4,5,6,7,8,9共9个数分成3组,分别组成3个三位数,且使这3个三位数的值构成1: ...

随机推荐

  1. nohup磁盘打满问题排查与解决

    使用nohup ... & 命令启动服务器后,磁盘满了,服务宕了,然后一步一步排查是哪个文件过大,最终定位到是nohup.out文件过大,占了40G, df -lh #磁盘容量命令 du -s ...

  2. C#操作XMl文件(2):使用XmlReader和XmlWriter实现读取和写入

    这次使用操作Xml较为常用的方法:使用XMlreader和Xmlwriter 1:读取xml文件的数学和元素 XmlReaderSettings settings = new XmlReaderSet ...

  3. 2.java设计模式-抽象工厂模式

    抽象工厂模式简介: 每一个模式都是针对某一种问题的解决方案.抽象工厂模式与工厂模式最大的区别在于,工厂模式针对的是一个产品等级结构,而抽象工厂模式面对的是多个产品等级结构,即产品族的概念. 这里讲解一 ...

  4. javaweb浏览器url上项目名称的更改

    如何改变上面url项目名称地址,如把04去掉改成teachershare 如下图:在项目设置中设置web context-root属性,将04去掉. 就可以用这个登录了. 要注意的是如果之前已经部署在 ...

  5. Thymeleaf学习记录(4)--$/*/#/@语法

    表达式符号 Thymeleaf对于变量的操作主要有$\*\#三种方式: 变量表达式: ${...},是获取容器上下文变量的值. 选择变量表达式: *{...},获取指定的对象中的变量值.如果是单独的对 ...

  6. 有标号的DAG计数系列问题

    传送门 II 设 \(f_i\) 表示 \(i\) 个点的答案 那么枚举至少 \(j\) 个点的出度为 \(0\) \[\sum_{j=0}^{i}(-1)^j\binom{i}{j}f_{i-j}2 ...

  7. SPOJ:LCS2 - Longest Common Substring II

    题面 给定一些字符串,求出它们的最长公共子串 输入格式 输入至多 \(10\) 行,每行包含不超过 \(100000\)个的小写字母,表示一个字符串 输出格式 一个数,最长公共子串的长度 若不存在最长 ...

  8. gulp 打包报错:Error: `libsass` bindings not found. Try reinstalling `node-sass`

    看了网上很多帖子 有说切换node版本的 有说卸载重新装gulp-sass的 有说删除node_modules重新install的 但是我测试了下在我们的电脑环境下都不行,后来找到一个可以打包不报错的 ...

  9. wampserver 更改www目录

    现在大家基本上开发php的有很大一部分都在用Wampserver,今天来讲讲怎么更改默认的www目录, 需要修改的文件有三个 apache2的配置文件 httpd.conf 和 Wampserver的 ...

  10. 支持n多视频网站的下载,推荐 you-get

    其实刚开始是想下载youtube视频, 网上找了下 其中之一:http://jingyan.baidu.com/article/39810a23d2deb2b637fda66c.html 访问一个在线 ...