#include <stdio.h> #include <stdlib.h> #include <time.h> #define N 5 int main() { int x, n; srand(time(0)); for(n=1; n<=N; n++) { x = rand() % 100; printf("%3d", x); } printf("\n"); return 0; }
#include <stdio.h> #include <stdlib.h> #include <time.h> int main() { int x, n ,i; srand(time(0)); x = rand() % 31+1; printf("猜猜2021年5月哪一天会是你的lucky day\n开始咯,你有三次机会,猜吧(1^31):",x); for(i=1;i<=3;i++){ scanf("%d",&n); if(n==x){ printf("你猜对了,%d日就是你的lucky day",x); break; } else if(n<x){ if(i<=2) printf("你猜的日期早了,lucky day还没到呢\n再猜:"); else printf("次数用完了,偷偷告诉你:你的lucky day是%d日",x); } else if(n>x){ if (i<=2) printf("你猜的日期晚了,lucky day悄悄溜到前面了\n再猜:"); else printf("次数用完了,偷偷告诉你:你的lucky day是%d日",x); } } return 0; }
#include<stdio.h> int main (){ long s; printf("enter a number:"); while((scanf("%ld",&s))!=EOF){ long t=0,p=1; while(s!=0) { if((s%10)%2!=0) { t=t+(s%10)*p; p=p*10; } s=s/10; } printf("new number is:%ld\n",t); printf("enter a number:"); } return 0; }
// 一元二次方程求解(函数实现方式) // 重复执行, 直到按下Ctrl+Z结束 #include <math.h> #include <stdio.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) != EOF) { solve(a, b, c); // 函数调用 printf("Enter a, b, c: "); } 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 = %.2f, x2 = %.2f\n", x1, x2); } else { real = -b/(2*a); imag = sqrt(-delta) / (2*a); printf("x1 = %.2f + %.2fi, x2 = %.2f - %.2fi\n", real, imag, real, imag); } } }
思考:函数只能有一个返回值,不能返回两个值
#include <stdio.h> double fun(int n); int main() { int n; double s; printf("Enter n(1~10): "); while(scanf("%d", &n) != EOF) { s = fun(n); printf("n = %d, s= %f\n\n", n, s); printf("Enter n(1~10): "); } return 0; } double fun(int n){ double s=1,x=1; int i; if(n==1) return 1; else{ for(i=2;i<=n;i++){ x=-x*1/i; s=s+x; } return s; } }
#include<stdio.h> #include<math.h> int isprime(int n); int main (){ int n,a=1,m=0; for(n=101;n<=200;n++) { if(isprime(n)) { printf("%d ",n); a++; m++; if(a%6==0) { printf("\n"); a=1; } } } printf("\n101~200之间素数个数为:%d\n",m); return 0; } int isprime(int n){ int k; for(k=2;k<=sqrt(n);k++) { if(n%k==0) return 0; } return 1; }