史萊姆論壇

返回   史萊姆論壇 > 專業主討論區 > 程式語言討論區
忘記密碼?
論壇說明

歡迎您來到『史萊姆論壇』 ^___^

您目前正以訪客的身份瀏覽本論壇,訪客所擁有的權限將受到限制,您可以瀏覽本論壇大部份的版區與文章,但您將無法參與任何討論或是使用私人訊息與其他會員交流。若您希望擁有完整的使用權限,請註冊成為我們的一份子,註冊的程序十分簡單、快速,而且最重要的是--註冊是完全免費的!

請點擊這裡:『註冊成為我們的一份子!』

Google 提供的廣告


發文 回覆
 
主題工具 顯示模式
舊 2007-01-04, 12:40 AM   #1
oya1340
長老會員
榮譽勳章
UID - 7194
在線等級: 級別:67 | 在線時長:4829小時 | 升級還需:67小時級別:67 | 在線時長:4829小時 | 升級還需:67小時級別:67 | 在線時長:4829小時 | 升級還需:67小時級別:67 | 在線時長:4829小時 | 升級還需:67小時級別:67 | 在線時長:4829小時 | 升級還需:67小時級別:67 | 在線時長:4829小時 | 升級還需:67小時級別:67 | 在線時長:4829小時 | 升級還需:67小時
註冊日期: 2002-12-09
文章: 15903
現金: 1934 金幣
資產: 108422717 金幣
預設 疑問 - 代人問一個c#的程式問題

要輸入二整數,使用輾轉相除法計算出最大公因數,但是限制程式中不可以使用『%』運算子
請問c#該如何寫才對呢?? 有點急請大家幫幫忙謝謝!!
oya1340 目前離線  
送花文章: 2688, 收花文章: 13383 篇, 收花: 57008 次
回覆時引用此帖
舊 2007-01-04, 11:52 AM   #2 (permalink)
註冊會員
 
snoopy 的頭像
榮譽勳章
UID - 33737
在線等級: 級別:49 | 在線時長:2676小時 | 升級還需:24小時級別:49 | 在線時長:2676小時 | 升級還需:24小時級別:49 | 在線時長:2676小時 | 升級還需:24小時級別:49 | 在線時長:2676小時 | 升級還需:24小時
註冊日期: 2003-02-02
VIP期限: 2011-06
住址: 台南共和國
文章: 1831
精華: 0
現金: 12744 金幣
資產: 12834 金幣
預設

這很簡單啊
去網路找找範例有一推寫好的
然後再改成 C# 就可以了
snoopy 目前離線  
送花文章: 623, 收花文章: 392 篇, 收花: 1288 次
回覆時引用此帖
舊 2007-01-04, 02:01 PM   #3 (permalink)
協調管理員
 
飛鳥 的頭像
榮譽勳章
UID - 23073
在線等級: 級別:72 | 在線時長:5513小時 | 升級還需:108小時級別:72 | 在線時長:5513小時 | 升級還需:108小時
註冊日期: 2003-01-07
VIP期限: 無限期
住址: 史萊姆團隊
文章: 7199
精華: 11
現金: 837 金幣
資產: 260029 金幣
預設

一開始在想,不能用%符號,好像很難做

但又想想,不用除法,用乘法+陣列也可以做出來

PHP 語法:
#include <iostream.h>
#include <stdio.h>
#include <stdlib.h>

main()
{
      
int no1,no2,a=0,b=0;
      
int an1[50]={0},an2[50]={0},an3[50]={0};

      
cout << "請輸入第一個數:";
      
cin >>no1;
      
cout << "請輸入第二個數:";
      
cin >>no2;
      
printf ("第一個數%d,二個數%d\n",no1,no2);
      
      
printf("=====%d====\t=====%d====\n",no1,no2);

      for(
int i=0;i<=no1;i++){
              for(
int j=0;j<=no2;j++){
                      if(
no1==i*j){
                         
printf ("%d X %d =%d\t",i,j,no1);
                         
an1[a]=i;
                         
an1[a+1]=j;
                         
a=a+2;         
                      }else if(
no2==i*j){printf ("\t\t");}
                      if(
no2==i*j){
                         
printf ("%d X %d =%d\n",i,j,no2);
                         
an2[b]=i;
                         
an2[b+1]=j;
                         
b=b+2;         
                      }else if(
no1==i*j){printf ("\n");}
              }

      }
      
printf("\n第一個數的因數:");
      for(
int i=0;i<=20;i++){
              if (
an1[i]!=0){
              
printf(" %d ",an1[i]);
              }
      }
      
printf("\n第二個數的因數:");
      for(
int i=0;i<=20;i++){
              if (
an2[i]!=0){
              
printf(" %d ",an2[i]);
               }
      }
      
      
      
//找出共同的因數放入an3陣列 
      
for(int i=0;i<30;i++){
              for(
int j=0;j<30;j++){
                      if(
an1[i]==an2[j]){an3[i]=an1[i];}
              }
      }
      
      
printf("\n\n%d和%d共同因數:",no1,no2);
      for(
int i=0;i<30;i++){
              if (
an3[i]!=0){
              
printf(" %d ",an3[i]);
              }
      }
      
      
      
//排序an3裡的,把最大數值放到an3[0] 
      
int change;
      for(
int i=0;i<30;i++){
              for(
int j=0;j<30;j++){
                      if(
an3[j]<an3[j+1]){
                                    
change=an3[j+1];
                                    
an3[j+1]=an3[j];
                                    
an3[j]=change;
                      }
              }
      }
      
printf("\n%d和%d的最大共因數為:%d\n",no1,no2,an3[0]);

      
printf("\n");
      
system("PAUSE");
      return 
0;

執行效果
PHP 語法:
請輸入第一個數:24
請輸入第二個數
:42
第一個數24,二個數42
=====24====     =====42====
1 X 24 =24
                1 X 42 
=42
2 X 12 
=24
                2 X 21 
=42
3 X 8 
=24
                3 X 14 
=42
4 X 6 
=24
6 X 4 
=24
                6 X 7 
=42
                7 X 6 
=42
8 X 3 
=24
12 X 2 
=24
                14 X 3 
=42
                21 X 2 
=42
24 X 1 
=24

第一個數的因數
1  24  2  12  3  8  4  6  6  4  8  3  12  2  24  1
第二個數的因數
1  42  2  21  3  14  6  7  7  6  14  3  21  2

24和42共同因數: 1  2  3  6  6  3  2  1
24和42的最大共因數為:6 
__________________
http://flybird017.googlepages.com/quok.gif http://flybird020.googlepages.com/new321.gif
寶貝你我的地球
, 請 少開電器,減少溫室氣體排放外,多種植植物,減少列印, 多用背面,丟棄時做垃圾分類。

http://netgames123.googlepages.com/tobikeways.jpg

飛鳥 目前離線  
送花文章: 11706, 收花文章: 3363 篇, 收花: 16453 次
回覆時引用此帖
舊 2007-01-05, 12:09 AM   #4 (permalink)
長老會員
榮譽勳章
UID - 7194
在線等級: 級別:67 | 在線時長:4829小時 | 升級還需:67小時級別:67 | 在線時長:4829小時 | 升級還需:67小時級別:67 | 在線時長:4829小時 | 升級還需:67小時級別:67 | 在線時長:4829小時 | 升級還需:67小時級別:67 | 在線時長:4829小時 | 升級還需:67小時級別:67 | 在線時長:4829小時 | 升級還需:67小時級別:67 | 在線時長:4829小時 | 升級還需:67小時
註冊日期: 2002-12-09
文章: 15903
現金: 1934 金幣
資產: 108422717 金幣
預設

先謝謝2位大大的教導.. 感恩你們..
飛鳥大你那程式還是用%了唷.. 不過没差啦我盡力幫我朋友找答案了還是不行那只好作罷啦..謝謝啦!!!
oya1340 目前離線  
送花文章: 2688, 收花文章: 13383 篇, 收花: 57008 次
回覆時引用此帖
舊 2007-01-05, 12:42 AM   #5 (permalink)
註冊會員
 
snoopy 的頭像
榮譽勳章
UID - 33737
在線等級: 級別:49 | 在線時長:2676小時 | 升級還需:24小時級別:49 | 在線時長:2676小時 | 升級還需:24小時級別:49 | 在線時長:2676小時 | 升級還需:24小時級別:49 | 在線時長:2676小時 | 升級還需:24小時
註冊日期: 2003-02-02
VIP期限: 2011-06
住址: 台南共和國
文章: 1831
精華: 0
現金: 12744 金幣
資產: 12834 金幣
預設

飛鳥大作的沒錯喔
他的 % 是印出字元
不是做除法
% 有很多用法
你們老師的要求一定是不能用 % 做除法
並非印出字元

所以這樣應該是可以的
snoopy 目前離線  
送花文章: 623, 收花文章: 392 篇, 收花: 1288 次
回覆時引用此帖
舊 2007-01-05, 01:10 AM   #6 (permalink)
協調管理員
 
飛鳥 的頭像
榮譽勳章
UID - 23073
在線等級: 級別:72 | 在線時長:5513小時 | 升級還需:108小時級別:72 | 在線時長:5513小時 | 升級還需:108小時
註冊日期: 2003-01-07
VIP期限: 無限期
住址: 史萊姆團隊
文章: 7199
精華: 11
現金: 837 金幣
資產: 260029 金幣
預設

引用:
作者: oya1340
先謝謝2位大大的教導.. 感恩你們..
飛鳥大你那程式還是用%了唷.. 不過没差啦我盡力幫我朋友找答案了還是不行那只好作罷啦..謝謝啦!!!
呵,叫你好好上課不上,有%這個字沒錯,不過不是%的功能

你們老師所說的是%功能是求餘數,跟我的%d不同

%d是要顯示出後面的變數用的,不是求餘數
飛鳥 目前離線  
送花文章: 11706, 收花文章: 3363 篇, 收花: 16453 次
回覆時引用此帖
舊 2007-01-05, 08:17 AM   #7 (permalink)
長老會員
榮譽勳章
UID - 7194
在線等級: 級別:67 | 在線時長:4829小時 | 升級還需:67小時級別:67 | 在線時長:4829小時 | 升級還需:67小時級別:67 | 在線時長:4829小時 | 升級還需:67小時級別:67 | 在線時長:4829小時 | 升級還需:67小時級別:67 | 在線時長:4829小時 | 升級還需:67小時級別:67 | 在線時長:4829小時 | 升級還需:67小時級別:67 | 在線時長:4829小時 | 升級還需:67小時
註冊日期: 2002-12-09
文章: 15903
現金: 1934 金幣
資產: 108422717 金幣
預設

引用:
作者: 飛鳥
呵,叫你好好上課不上,有%這個字沒錯,不過不是%的功能

你們老師所說的是%功能是求餘數,跟我的%d不同

%d是要顯示出後面的變數用的,不是求餘數
不是我啦~~ 我會跟她說的..說她上課不好好聽課...老師在講沒再聽唷作業不會寫了吧~~活該~
oya1340 目前離線  
送花文章: 2688, 收花文章: 13383 篇, 收花: 57008 次
回覆時引用此帖
向 oya1340 送花的會員:
chenhan2603 (2009-01-27)
感謝您發表一篇好文章
發文 回覆



發表規則
不可以發文
不可以回覆主題
不可以上傳附加檔案
不可以編輯您的文章

論壇啟用 BB 語法
論壇啟用 表情符號
論壇啟用 [IMG] 語法
論壇禁用 HTML 語法
Trackbacks are 禁用
Pingbacks are 禁用
Refbacks are 禁用


所有時間均為台北時間。現在的時間是 08:52 PM


Powered by vBulletin® 版本 3.6.8
版權所有 ©2000 - 2024, Jelsoft Enterprises Ltd.


SEO by vBSEO 3.6.1