实验四

#include<stdio.h>
long long fun(int n); //函数声明

int main()
{
    int n;
    long long f;
    
    while(scanf("%d",&n)!=EOF)
    {
        f=fun(n); //函数调用
        printf("n=%d,f=%11d\n",n,f); 
    }
    
    return 0;
 } 
 
 //函数定义
 long long fun(int n)
 {
     int ans=1;
     for(int i=1;i<=n;i++)
     {
         ans=ans*2;
     }
     
     ans=ans-1;
     
     return ans;
  } 

//利用局部static变量计算阶乘

#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!=%11d\n",i,fac(i));
    
    return 0;
 } 
 
 //函数定义
 long long fac(int n)
 {
     static long long p=1;
     
     p=p*n;
     
     return p;
  } 

//利用局部static变量计算阶乘

#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);
}

//寻找两个整数之间的所有素数(包括这两个整数),把结果保存在数组bb中,函数返回素数的个数
//例如,输入6和21,则输出:7 11 13 17 19

#include<stdio.h>

#define N 1000
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)
        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>
void dec2n(int x,int n);//函数声明

int main()
{
    int x;
    
    printf("输入一个十进制整数:");
    scanf("%d",&x);
    
    dec2n(x,2);//函数调用:把x转换为二进制输出
    dec2n(x,8);//函数调用:把x转换成八进制输出
    dec2n(x,16);//函数调用:把x转换成十六进制输出
    
    return 0; 
 } 
 
 //函数定义
 //功能:把十进制数x转换成n进制,打印输出
 //补足函数实现
 void dec2n(int x,int n)
 {
     int i=1,j;
     char a[999];
     if(x<0)
     {
         printf("-");
         x=-x;
     }
     i=1;
     while(x>0)
     {
         a[i]=x%n+'0';
         if(a[i]>='0'+10)
         a[i]='A'+a[i]-'0'-10;
         x=x/n;
         i++;
     }
     for(j=i-1;j>=1;j--)
     printf("%c",a[j]);
     printf("\n");
  } 

posted @ 2021-04-25 19:48  Hik~  阅读(35)  评论(1编辑  收藏  举报