java 倍数_Java硬币翻转倍数递增试算实例

import java.util.Scanner;

/**

*

* @author cc 举例 100枚硬币,最初全部朝下,第一次将所有硬币反转过来, 第二次反转位置是2的倍数的硬币,

*         第三次反转3的倍数,.....执行一百次,问最终共有多少个硬币面朝上?

*

*         1.硬币正反使用数组 1、0表示,1表示正面,0表示反面;

*

*

*         100枚硬币的结果

int[] ==  1100100001000000100000000100000000001000000000000100000000000000100000000000000001000000000000000000

result coin about 1 nums = 10

*/

public class CoinTurn {

private static int[] intCoins;

public static void main(String[] args) {

// TODO Auto-generated method stub

int coinNum = inputNum();

intCoins = new int[coinNum];

/*

* 初始化

*/

for (int i = 0; i < intCoins.length; i++) {

intCoins[i] = 0;// 初始化全部朝下,即背面0

}

doTurnCoin();

int resutltCoin = getCoinNum();

System.out.println("result coin about 1 nums = " + resutltCoin);// 输出最终正面朝上的个数

}

private static void doTurnCoin() {

/*

* 翻转操作

*/

for (int i = 1; i < intCoins.length; i++) {// 确定倍数

for (int j = i - 1; j < intCoins.length; j++) {// 循环翻转

if (j % i == 0) { // 硬币序列数是当前次数的倍数,则翻转

if (intCoins[j] == 0) {

intCoins[j] = 1;

} else {

intCoins[j] = 0;

}

}

}

}

}

private static int getCoinNum() {

int countNum = 0;// 记录最终硬币正面个数

StringBuffer strB = new StringBuffer();

for (int a : intCoins) {

strB.append(a + "");

if (1 == a)

countNum++;

}

System.out.println("int[] ==  " + strB);// 输出数组的结果

return countNum;

}

/*

* coin number

*/

private static int inputNum() {

System.out.println("input coin num: ");

Scanner input = new Scanner(System.in);

return input.nextInt();

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值