9-1 series1.c

 #include <stdio.h>
 int main()
 {
     float s=0.0,k;
     int n;
     printf("输入数字k(1~15):");
     scanf("%f",&k);
     n=;
     do{
         n++;
         s+=1.0/(float)n;
     }while(k>=s);
     printf("n=%d\n",n);
     getch();
     ;
 }

9-2 series2.c

 #include <stdio.h>
 #define MAXN 100    //数组最大下标值
  }, s[MAXN] =
 {
 };    //dec保存n的倒数,s保存结果值
 int calc(int k)
 {
    ;
    s[] = s[] = ;
    do
    {
       n++;
       dec[] =  / n;
       residue =  % n;    //余数
       ; i < MAXN; i++)    //求1/n
       {
          div = residue * ;    //将余数扩大10倍
          residue = div % n;    //得到余数
          dec[i] = div / n;    //保存商
       }
       //计算sn
       div = ;
       carry = ;    //进位
       ; i >= ; i--)    //从低位开始逐位相加
       {
          div = dec[i] + s[i] + carry;    //累加一位和进位值
          carry = div / ;    //进位
          s[i] = div % ;    //保留一位数
       }
       s[] = s[] + carry;    //加进位(K最大为15,b[0]保存10位数
    }
    ] *  + s[] < k);
    return n;
 }
 int main()
 {
    int k, n;
    printf("输入数字k(1~15):");
    scanf("%d", &k);
    )
    {
       printf("n=2\n");
       getch();
       ;
    } else
    {
       n = ;
       n = calc(k);
    }
    printf("n=%d\n", n);
    getch();
    ;
 }

9-3 prime.c

 #include <stdio.h>
 #define  MAXN  20
 char N, K;    //N保存整数个数,选M个数相加
 int iCount, Sum;
 int Num[MAXN];    //保存输入的MAXN个数
 ];    //保存1~10000之间的数,若下标为素数,则元素值为1
 ];    //保存素数
 int List[MAXN];    //保存列表
 void GenPrime() //用筛选法将2~10000之间的素数选出来
 {
    ;
    Flag[] = Flag[] = ;
    ; i <= ; i++)    //初始化数组
       Flag[i] = ;
    ; i <= ; i++)
    {
       )    //
       {
          Prime[s++] = i;    //保存第s个素数为i
          j =  * i;
          )
          {
             Flag[j] = ;
             j = j + i;    //将i的倍数筛选掉
          }
       }
    }
 }
 void IsPrime(int s)
 {
    ;    //flag若为0,表示flag是素数
    )    //小于10000,直接判断是否为素数
    {
       if (Flag[s])    //若s是素数
          iCount++;    //增加计数器
    }
    else    //若累加和大于10000,需单独判断是否为素数
    {
       i = ;
       while (Prime[i] * Prime[i] < s)    //s大于Prime[i]的平方
       {
          )    //若s能被某个素数整除
          {
             flag = ;    //表示s不是素素
             break;    //退出循环
          }
          i++;
       }
       )    //若是素数
          iCount++;    //累加素数计数器
    }
 }
 void Try(int d, int pre)    //在N个数据中查找
 {
    int i;
    for (i = pre; i < N - (K - d); i++)
    {
       Sum += Num[i];    //累加整数
       List[d - ] = i;
       if (d == K)    //若累加的整数个数等于K个
          IsPrime(Sum);    //调用函数判断Sum是否为素数
       else    //若不等于K个
          Try(d + , i + );    //递归调用,累加下一个整数
       Sum -= Num[i];    //回溯,减去前1个整数
    }
 }
 int main()
 {
    int i;
    FILE *fp1, *fp2;
    if ((fp1 = fopen("prime.in", "r")) == NULL)
    {
       printf("不能打开文件!\n");
       exit();
    }
    fscanf(fp1, "%d%d\n", &N, &K);
    ; i < N; i++)    //逐个输入N个数
       fscanf(fp1, "%d", &Num[i]);
    fclose(fp1);
    iCount = ;    //计数器
    Sum = ;    //累加和清0
    GenPrime();    //调用函数生成素数,保存在数组p中
    Try(, );    //反复查找
    if ((fp2 = fopen("prime.out", "w")) == NULL)
    {
       printf("不能打开文件!\n");
       exit();
    }
    printf("%d\n", iCount);  //输出结果数量
    fprintf(fp2, "%d\n", iCount);
    fclose(fp2);
    getch();
    ;
 }

9.1 NOIP普及组试题精解(1)的更多相关文章

  1. 9.1 NOIP普及组试题精解(2)

    9-4 soldier.c #include <stdio.h> #define MAXN 21 }; int n, m, x, y; //n,m为B点的行列坐标位置,x,y为马的坐标位置 ...

  2. 9.1 NOIP普及组试题精解(3)

    9-6 seat.c #include <stdio.h> #define MAXN 1001 void swap(int *a, int *b) //交换数据 { int t; t = ...

  3. 9.2 NOIP提高组试题精解(2)

    9-18 fruit.c #include <stdio.h> #define MAXN 10000 int Queue1[MAXN], Queue2[MAXN]; void Insert ...

  4. 9.2 NOIP提高组试题精解(1)

    9-16 poise.c #include <stdio.h> #define MAXN 1001 int main() { ], flag[MAXN] = { }; //保存6种砝码的数 ...

  5. 2016.10.6初中部上午NOIP普及组比赛总结

    2016.10.6初中部上午NOIP普及组比赛总结 中了病毒--病毒--病毒-- 进度: 比赛:AC+0+0+20=120 改题:AC+0+AC+20=220 Stairs 好--简--单!递推就过了 ...

  6. 2016.8.15上午纪中初中部NOIP普及组比赛

    2016.8.15上午纪中初中部NOIP普及组比赛 链接:https://jzoj.net/junior/#contest/home/1333 这次比赛不怎么好,因为这套题目我并不是很擅长. 可同学们 ...

  7. 2016.9.15初中部上午NOIP普及组比赛总结

    2016.9.15初中部上午NOIP普及组比赛总结 2016.09.15[初中部 NOIP普及组 ]模拟赛 又翻车了!表示时超和空超很可恨! 进度 比赛:AC+0+0+20=120 改题:AC+80+ ...

  8. 2016.9.10初中部上午NOIP普及组比赛总结

    2016.9.10初中部上午NOIP普及组比赛总结 链接:https://jzoj.net/junior/#contest/home/1340 好不爽!翻车了!不过排名差不多在中间偏上一点, 还好不是 ...

  9. 2016.9.3初中部上午NOIP普及组比赛总结

    2016.9.3初中部上午NOIP普及组比赛总结 链接:https://jzoj.net/junior/#contest/home/1339 这次真爽,拿了个第四!(我还被班主任叫过去1小时呢!) 进 ...

随机推荐

  1. JAVA_Could not find property [struts.actionMapping]怎么办

    你的项目中不包含log4j.jar这个文件,包含进去即可

  2. PHP提权之异步执行

    在服务器上都会定时运行一些脚本以完成周期性的任务. 而这些脚本往往是以root权限启动的, 替换或者改变其中的内容就可以完成提权.而今天在这要讲解的就是php提权中的异步执行方法. 在php中一般大家 ...

  3. Erlang 督程 启动和结束子进程

    1.督程: test_sup 2.子进程:test_gen_server 3.子进程规格Spec: { test_gen_server, {test_gen_server, start_link, [ ...

  4. 非常酷的word技巧---删除行前的空格

    今天整理一篇文章的时间遇见一个问题,非常多行前的空格严重影响美观.搞计算机的就是爱折腾.于是做了各种尝试完美解决,以下把方法发布例如以下,事实上非常easy哦! 问题例如以下情况所看到的: 解决的方法 ...

  5. C语言数据类型的转换

    C语言的类型转换,一个是强制类型进行转换,而在这里要介绍的是自动的数据类型的转换,自动的数据类型转换很多时候是发生在多种数据类型混合使用的时候就会进行类型的转换,这样就会带来不能控制的结果,所以必须进 ...

  6. jquery代码小片段

    1. 使用jQuery来切换样式表 //找出你希望切换的媒体类型(media-type),然后把href设置成新的样式表. $(‘link[media="screen"]‘).at ...

  7. onscreen and offscreen

    本文来自stackoverflow一位网友的解答,感觉非常不错就摘录了. --------------------------------------------------------------- ...

  8. android Bluetooth-蓝牙

    bluetooth 一.开启蓝牙 1.获取BluetoothAdapter BluetoothAdapter.getDefaultAdapter() 2.判断手机设备是否 有蓝牙模块 3.开启蓝牙设备 ...

  9. 继续封装DBDA.php 加入ajax

    <?php class DBDA { public $host = "localhost"; //服务器地址 public $uid = "root"; ...

  10. EasyPlayerPro windows播放器在播放RTMP视频显示重复异常问题解决

    问题来源 2017.12.18 今日有杭州某教育领域客户反馈EasyPlayerPro在播放一个rtmp源时,画面显示异常的问题.截图如下: 问题复现 一番思考, 将显示格式改为D3D显示, 正常, ...