一步之遥

从昏迷中醒来,小明发现自己被关在X星球的废矿车里。
矿车停在平直的废弃的轨道上。
他的面前是两个按钮,分别写着“F”和“B”。
小明突然记起来,这两个按钮可以控制矿车在轨道上前进和后退。
按F,会前进97米。按B会后退127米。
透过昏暗的灯光,小明看到自己前方1米远正好有个监控探头。
他必须设法使得矿车正好停在摄像头的下方,才有机会争取同伴的援助。
或许,通过多次操作F和B可以办到。
矿车上的动力已经不太足,黄色的警示灯在默默闪烁…
每次进行 F 或 B 操作都会消耗一定的能量。
小明飞快地计算,至少要多少次操作,才能把矿车准确地停在前方1米远的地方。
请填写为了达成目标,最少需要操作的次数。

将满足条件的值存储到数组中。遍历数组得到其中的最小值即可。

c++代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include<stdio.h>

int main(){
int count[100]=0,m=0;

for(int i=0;i<101;i++)
{
for(int j=0;j<101;j++){
if(97*i-127*j==1){
count[m++]=i+j;
}
}
}
min=count[0];
for(i=0;i<100;i++){
if(count[i]&&count[i]<min){
min=count[i];
}
}
printf("%4d\n",min);
}

java代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
public class md {
public static void main(String[] args){
int[] count=new int[100];
int m=0;
for(int i=0;i<100;i++){
for(int j=0;j<100;j++){
if(i*97-j*127==1){
count[m++]=i+j;
}
}
}
int min=count[0];
for(int k=0;k<100;k++){
if(count[k]>min){
min=count[k];
}
}
System.out.print(min);
}
}

结果:97