标签:std 素数 内存 多层 字符 adr png out code
#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"); }
//寻找两个整数之间的所有素数(包括这两个整数),把结果保存在数组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) 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( j>=i ) 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=2; i<=k; i++) { if( i%2==0&&k%i==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 com(char x[],int n) ; int main() { char string[N] = {‘2‘,‘0‘,‘1‘,‘9‘}; int i; printf("排序前: \n"); output(string, N); com(string,N); printf("\n排序后: \n"); output(string, N); printf("\n"); system("pause"); return 0; } void output(char x[], int N) { int i; for(i=0; i<N; i++) printf("%c", x[i]); } void com(char x[],int N){ int j,i,t; for(j=0;j<N-1;j++) for(i=0;i<N-j-1;i++) if(x[i]<x[i+1]) {t=x[i]; x[i]=x[i+1]; x[i+1]=t; } }
心得:
1.在多层循环时循环条件,以及初值要考虑好,否则会出现奇怪的结果。
2.不要把函数里的数组和主函数里数组名弄混。
标签:std 素数 内存 多层 字符 adr png out code
原文地址:https://www.cnblogs.com/yehang/p/11938761.html