java - C語言的一道關于循環的練習題求解
問題描述
做這道題目沒什么思路?不知道該怎么下手,求大神講解一下
問題解答
回答1:http://blog.csdn.net/houyp520...
回答2:最簡單的話就是窮舉9個數的排列。
優化一點就是先排除一些不可能的情況。比如中間的數是2的倍數,最后的數是3的倍數。諸如此類。
回答3:寫個遞歸好了。。或者叫迭代?
回答4:public class Sidney {
public static void main(String[] args) { int[] s = new int[9]; for (int i = 300; i < 999; i+=3) {int flag = 1;Set<Integer> set = new HashSet<>();int a = i / 3;int b = (i / 3) * 2;s[0]=a%10;s[1]=a%100/10;s[2]=a/100;s[3]=b%10;s[4]=b%100/10;s[5]=b/100;s[6]=i%10;s[7]=i%100/10;s[8]=i/100;for (int i1 : s) { if (!set.add(i1) || i1 == 0) {flag = 0;break; }}if (flag == 1) { System.out.println(a + 't' + b + 't' + i);} }}
}
回答5:劉汝佳的題啊。
枚舉第一個數, 也就是1:2:3中占比1的那個數。
枚舉范圍是123~345。根據這個數,去計算其他兩個數,然后判定是否恰好用了9個數字即可。
回答6:思路很簡單,既然要讓比例為1:2:3且每個數要用一次,那就直接將1,2,3各放大x倍,然后判斷是否滿足每個數僅出現一次即可。1只少放大100倍才能達到3位數,所以直接從123開始即可。代碼如下。int testa(){
int a=1,b=2,c =3;char szA[10]={0},szB[4]={0},szC[4]={0},cTag[10]={0};for(int i=123;i<=333;i++){ memset(szA,0x00,10);memset(szB,0x00,4);memset(szC,0x00,4);memset(cTag,0x00,10); sprintf_s(szA,'%d',a*i);sprintf_s(szB,'%d',b*i);sprintf_s(szC,'%d',c*i); strcat_s(szA,szB);strcat_s(szA,szC); int j=0; for(j=0;j<9;j++) {if(cTag[szA[j]-’1’]!=0) break;cTag[szA[j]-’1’]=1; } if(j==9)printf('%sn',szA);}return 0;
}
相關文章:
1. javascript - ie11以下單擊打開不了file,雙擊可以。求解?2. javascript - 關于定時器 與 防止連續點擊 問題3. javascript - 關于這組數據如何實現 按字母列表分類展示 不改動數據結構4. javascript - 寫移動端的頁面的時候,有不一快空白,是怎么回事?5. javascript - 求助這種功能有什么好點的插件?6. objective-c - ios百度地圖定位問題7. 微信開放平臺 - Android調用微信分享不顯示8. html5 - rudy編譯sass的時候有中文報錯9. javascript - 在IE中(9+)平時的樣式不生效,只有用開發者工具選中這個元素才生效,是什么原因?10. Python做掃描,發包速度實在是太慢了,有優化的方案嗎?
