1. 程式人生 > 實用技巧 >Java從入門到實戰之(33)Java中23種設計模式

Java從入門到實戰之(33)Java中23種設計模式

任務1

回答:不能,因為程式中並不需要函式返回值,只是執行呼叫函式。

任務2

#include<stdio.h>
long long fac(int n);
int main(){
    int i,n;
    printf("Enter n: ");
    scanf("%d",&n);
    for(i=1;i<=n;++i){
        printf("%d!=%lld\n",i,fac(i));
    }
return 0;
}

long long fac(int n){
    static long long p=1;
    printf(
"p=%lld\n",p); p=p*n; return p; }

#include<stdio.h>
int func(int,int);
int main(){
    int k=4,m=1,p1,p2;
    
    p1=func(k,m);
    p2=func(k,m);
    printf("%d,%d\n",p1,p2);
    return 0;
}

int func(int a,int b){
    static int m=0,i=2;
    i+=m+1;
    m=i+a+b;
    return (m); 
}

一致,static變數在函式中,每次執行都會儲存上次執行的結果

任務3

#include<stdio.h>
#define N 100
int fun(int n,int m,int bb[N]){
    int i,j,k=0,flag;
    for(j=n;j<=m;j++){
        flag=1;
        for(i=2;i<j;i++)
            if(j%i==0){
                flag=0;
                break;
            }
            if(flag==1)
                bb[k++]=j; 
        }
        
return k; } int main(){ int n=0,m=0,i,k,bb[N]; scanf("%d",&n); scanf("%d",&m); for(i=0;i<m-n;i++) bb[i]=0; k=fun(n,m,bb); for(i=0;i<k;i++){ printf("%4d",bb[i]); } return 0; }

#include <stdio.h>
long long fun(int n);   // 函式宣告 

int main() {
    int n;
    long long unsigned f;
    
    while(scanf("%d", &n) != EOF) {
        f = fun(n);  // 函式呼叫 
        printf("n = %d, f = %lld\n", n, f);
    }
    
    return 0;
}

long long fun(int n){
    long long unsigned result;
    if(n==1){
        result=1;}
    else{
    result=2*fun(n-1)+1;
    }
    return result;
}

任務5

#include <stdio.h>

void draw(int n, char symbol);  // 函式宣告 

#include <stdio.h> 
int main() {
    int n, symbol;
    
    while(scanf("%d %c", &n, &symbol) != EOF) {
        draw(n, symbol);  // 函式呼叫 
        
        printf("\n");
    }
    
    return 0;
} 


void draw(int n,char symbol){
    
    for(int i=1;i<=n;i++){
        for(int count=1;count<=n-i;count++){
            printf(" ");
        }
        for(int x=1;x<=2*i-1;x++){
            printf("%c",symbol);
        }
        for(int count=1;count<=n-i;count++){
            printf(" ");
        }
        printf("\n");
    }
}

總結:任務4中最後結果如果沒有考慮大數字演算法,表示式換種較為複雜的方式表達,可能會導致輸入32時,結果短時間內難以輸出甚至不輸出