Java硬幣翻轉(zhuǎn)倍數(shù)遞增試算實例
//有何不足或者問題希望能夠得到各位的多多指正,不勝感激
import java.util.Scanner;
/**
*
* @author cc 舉例 100枚硬幣,最初全部朝下,第一次將所有硬幣反轉(zhuǎn)過來, 第二次反轉(zhuǎn)位置是2的倍數(shù)的硬幣,
* 第三次反轉(zhuǎn)3的倍數(shù),.....執(zhí)行一百次,問最終共有多少個硬幣面朝上?
*
* 1.硬幣正反使用數(shù)組 1、0表示,1表示正面,0表示反面;
*
*
* 100枚硬幣的結(jié)果
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);// 輸出最終正面朝上的個數(shù)
}
private static void doTurnCoin() {
/*
* 翻轉(zhuǎn)操作
*/
for (int i = 1; i < intCoins.length; i++) {// 確定倍數(shù)
for (int j = i - 1; j < intCoins.length; j++) {// 循環(huán)翻轉(zhuǎn)
if (j % i == 0) { // 硬幣序列數(shù)是當(dāng)前次數(shù)的倍數(shù),則翻轉(zhuǎn)
if (intCoins[j] == 0) {
intCoins[j] = 1;
} else {
intCoins[j] = 0;
}
}
}
}
}
private static int getCoinNum() {
int countNum = 0;// 記錄最終硬幣正面?zhèn)€數(shù)
StringBuffer strB = new StringBuffer();
for (int a : intCoins) {
strB.append(a + "");
if (1 == a)
countNum++;
}
System.out.println("int[] == " + strB);// 輸出數(shù)組的結(jié)果
return countNum;
}
/*
* coin number
*/
private static int inputNum() {
System.out.println("input coin num: ");
Scanner input = new Scanner(System.in);
return input.nextInt();
}
}
相關(guān)文章
詳解Java正則表達(dá)式中Pattern類和Matcher類
java.util.regex是一個用正則表達(dá)式所訂制的模式來對字符串進(jìn)行匹配工作的類庫包。包括兩個類Pattern和Matcher Pattern,Pattern是一個正則表達(dá)式經(jīng)編譯后的表現(xiàn)模式。Matcher對象是一個狀態(tài)機(jī)器,它依據(jù)Pattern對象做為匹配模式對字符串展開匹配檢查。2016-12-12Spring零基礎(chǔ)入門WebFlux響應(yīng)式編程
Spring 提供了兩個并行堆棧,一種是基于帶有 Spring MVC 和 Spring Data 結(jié)構(gòu)的 Servlet API,另一個是完全反應(yīng)式堆棧,它利用了 Spring WebFlux 和 Spring Data 的反應(yīng)式存儲庫,這篇文章主要介紹了Spring-webflux 響應(yīng)式編程,需要的朋友可以參考下2022-10-10詳解Java中ExceptionInInitializer錯誤的解決方法
ExceptionInInitializerError 是 Java 中的未經(jīng)檢查的異常,它是 Error 類的子類, 它屬于運(yùn)行時異常的類別,下面我們就來看看它的具體解決方法吧2024-02-02在IDEA中搭建最小可用SpringMVC項目(純Java配置)
這篇文章主要介紹了在IDEA中搭建最小可用SpringMVC項目(純Java配置),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12Java畢業(yè)設(shè)計實戰(zhàn)之線上水果超市商城的實現(xiàn)
這是一個使用了java+SSM+springboot+redis開發(fā)的網(wǎng)上水果超市商城,是一個畢業(yè)設(shè)計的實戰(zhàn)練習(xí),具有水果超市商城該有的所有功能,感興趣的朋友快來看看吧2022-01-01