码迷,mamicode.com
首页 > 其他好文 > 详细

实验四

时间:2019-12-03 23:04:58      阅读:73      评论:0      收藏:0      [点我收藏+]

标签:素数   can   n个元素   二次   a*   描述   com   sleep   设置   

Part1:

#include <math.h>
#include <stdio.h>
#include <stdlib.h>

// 函数声明
void solve(double a, double b, double c);

// 主函数 
int main() {
    double a, b, c;
    
    printf("Enter a, b, c: ");
    while(scanf("%lf%lf%lf", &a, &b, &c)) {
        solve(a, b, c);  // 函数调用 
        printf("Enter a, b, c: ");
    }
    
    system("pause");
    return 0;
}

// 函数定义
// 功能:求解一元二次方程,打印输出结果
// 形式参数:a,b,c为一元二次方程系数 
void solve(double a, double b, double c) {
    double x1, x2;
    double delta, real, imag;
    
    if(a == 0) 
        printf("not quadratic equation.\n");
    else {
        delta = b*b - 4*a*c;
        
        if(delta >= 0) {
            x1 = (-b + sqrt(delta)) / (2*a);
            x2 = (-b - sqrt(delta)) / (2*a);
            printf("x1 = %f, x2 = %f\n", x1, x2);
        }
        else {
            real = -b/(2*a);
            imag = sqrt(-delta) / (2*a);
            printf("x1 = %f + %fi, x2 = %f - %fi\n", real, imag, real, imag);
        }
    }    
}

技术图片

// 在屏幕画布指定坐标(x,y)处打印圆圈(圆圈用大写字符O代替)

#include <stdio.h>
#include <stdlib.h>
#include <windows.h>

// 函数声明
void printCircle(int x, int y); 

int main() {
    
    system("color 02"); // 设置屏幕为黑底绿色 
    
    printCircle(5, 10);  // 调用函数,在坐标(5,10)打印圆圈 
    Sleep(5000);  // 延时5000ms,即5s 
    
    system("cls");  // 清除屏幕
    printCircle(10, 5);  // 调用函数,在坐标(10,5)打印圆圈 
    
    system("pause");
    return 0;
}

// 函数定义
// 在屏幕坐标(x,y)处打印圆圈 
void printCircle(int x, int y) {
    int line, col;
    
    // 打印y-1行空白行
    for(line = 1; line <= y-1; line++)
        printf("\n");
        
    // 在第y行打印x-1格空格
    for(col = 1; col <= x-1; col++) 
        printf(" ");  // 双引号里有空格。这里是打印一个空格
        
    // 在(x,y)坐标处答应圆圈,圆圈用大写字符O代替 
    printf("O");
    
    printf("\n");
}

技术图片

Part2:

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

#include <stdio.h>
#include <stdlib.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!=0) 
           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]);
    
    system("pause");
        
    return 0;
}

技术图片


技术图片






#include<stdio.h> #include<stdlib.h> #define N 100 void fun(int x[N][N],int n) { int i,j; for(i=1;i<=n;i++) for(j=1;j<=n;j++) if( i<=j ) x[i][j]=i; else x[i][j]= j ; } int main() { int n,i,j,a[N][N]; scanf("%d",&n); fun(a,n); for(i=1;i<=n;i++) { for(j=1;j<=n;j++) printf("%d ",a[i][j]); printf("\n"); } system("pause"); return 0; }

技术图片技术图片

// 函数fun()的功能是: 找出能够被x整除并且是偶数的数,
// 把这些数保存在数组bb中,并按从大到小的顺序输出。 
// 例如,当x=20时,依次输出: 20 10 4 2。  
#include <stdio.h>
#include <stdlib.h> 
void fun(int k,int bb[]) {
    int i;
    int j=0;
    
    for(i=1; i<=k; i++)  {  
         if( k%i==0&&i%2==0 )    
            bb[j++]=i;
    }

    for(i=j-1; i>=0; i--)  // blank3
        printf("%d ",bb[i]);
}

int main() {
    int x, *t;
    
    scanf("%d", &x);
    
    // 向系统申请sizeof(int)*x个字节的内存空间
    // 如果申请成功,将系统分配的内存的首地址赋值给t 
    t = (int *) malloc(sizeof(int)*x);
    
    fun(x,t);
    
    system("pause");
    return 0;
}

技术图片技术图片技术图片

#include <stdio.h>
#include <stdlib.h>
const int N=4;
void output(char x[], int n);
void fun(char c[N]);
 // 函数声明 
// 排序函数声明
// 补足代码1 
// 。。。 
void fun(char c[N]);

int main() {
    char string[N] = {2,0,1,9};
    int i;
    
    printf("排序前: \n");
    output(string, N);
    
    // 调用排序函数对字符数组中的字符由大到小排序 
    // 补足代码2 
    // 。。。 
    fun(string);
    printf("\n排序后: \n"); 
    output(string, N);
    
    printf("\n");
    
    system("pause");
    return 0;    
} 

// 函数定义
// 函数功能描述:输出包含有n个元素的字符数组元素
// 形参:字符数组,以及字符数组元素个数
void output(char x[], int n) {
    int i;
    
    for(i=0; i<N; i++)
        printf("%c", x[i]);
} 

// 函数定义
// 函数功能描述:对一组字符由大到小排序
// 形参:字符数组,以及字符数组元素个数
// 补足代码3 
// 。。。 
void fun(char c[N])
{
  int i,j,k;
  for(i=0;i<N-1;i++)
  for(j=0;j<N-1;j++)
  if(c[j]<c[j+1])
  {
      k=c[j];
      c[j]=c[j+1];
      c[j+1]=k;
      
  }
}

技术图片

 

ps:最后一种题型不太会,时间用了挺长的

实验四

标签:素数   can   n个元素   二次   a*   描述   com   sleep   设置   

原文地址:https://www.cnblogs.com/bkycyy/p/11980064.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!