C语言编程练习——循环结构(二)

帮一个 C语言小白 朋友撸代码,改进的空间还有很大,希望大神多多指教!

一、奇偶分家

给定N个正整数,请统计奇数和偶数各有多少个?
输入格式:
输入第一行给出一个正整N(≤1000);第2行给出N个非负整数,以空格分隔。加粗样式
输出格式:
在一行中先后输出奇数的个数、偶数的个数。中间以1个空格分隔。
输入样例:

9
88 74 101 26 15 0 34 22 77

输出样例:

3 6

#include<stdio.h>
int main()
{
 int N,count1 = 0,count2 = 0,num;
    scanf("%d",&N);
 while(N){
  scanf("%d",&num);
  N--;
  if(num % 2 == 1){
   count1++;
  }else{
   count2++;
  }
 }
 printf("%d %d",count1,count2);
 return 0;
}

二、求交错序列前N项和

本题要求编写程序,计算交错序列 1-2/3+3/5-4/7+5/9-6/11+… 的前N项之和。
输入格式:
输入在一行中给出一个正整数N。
输出格式:
在一行中输出部分和的值,结果保留三位小数。
输入样例:

5

输出样例:

0.917

#include<stdio.h>
int main()
{
 int N,i;
 float sum = 0.0;
 scanf("%d",&N);
 for(i = 1; i <= N; i++){
  if(i % 2 == 1){
   sum += i * 1.0 / (2 * i - 1);
  }else{
   sum -= i * 1.0 / (2 * i - 1);
  }
 }
 printf("%.3f",sum);
 return 0;
}

三、最大公约数和最小公倍数

本题要求两个给定正整数的最大公约数和最小公倍数。
输入格式:
输入在一行中给出两个正整数M和N(≤1000)。
输出格式:
在一行中顺序输出M和N的最大公约数和最小公倍数,两数字间以1空格分隔。
输入样例:

511 292

输出样例:

73 2044

#include<stdio.h>
int main()
{
 int M,N,yueshu,beishu,i;
 scanf("%d %d",&M,&N);
 int x = (M < N) ? M : N;
 for(i = x; i >= 1; i--){
  if(M % i == 0 && N % i == 0){
   yueshu = i;
   break;
  }
 }
 int y = (M > N) ? M : N;
 while(1){
  if(y % M == 0 && y % N == 0){
   beishu = y;
   break;
  }
  y++;
 }
 printf("%d %d",yueshu,beishu);
 return 0;
}

四、 统计字符

本题要求编写程序,输入10个字符,统计其中英文字母、空格或回车、数字字符和其他字符的个数。
输入格式:
输入为10个字符。最后一个回车表示输入结束,不算在内。
输出格式:
在一行内按照letter = 英文字母个数, blank = 空格或回车个数, digit = 数字字符个数, other = 其他字符个数
的格式输出。
输入样例:

aZ &
09 Az

输出样例:

letter = 4, blank = 3, digit = 2, other = 1

#include <stdio.h>
int main()
{
 int N = 10,letter = 0,digit = 0,other = 0,blank = 0;
 char ch;
 while(N >= 1){
  scanf("%c",&ch);
  if(ch >= 65 && ch <= 90 || ch >= 97 && ch <= 122){
   letter++;
  }else if(ch >= 48 && ch <= 57){
   digit++;
  }else if(ch == 10 || ch == 32){
            blank++;
        }else{
   other++;
  }
  N--;
 }
 printf("letter = %d, blank = %d, digit = %d, other = %d",letter,blank,digit,other);
 return 0;
}

五、大笨钟

微博上有个自称“大笨钟V”的家伙,每天敲钟催促码农们爱惜身体早点睡觉。不过由于笨钟自己作息也不是很规律,所以敲钟并不定时。一般敲钟的点数是根据敲钟时间而定的,如果正好在某个整点敲,那么“当”数就等于那个整点数;如果过了整点,就敲下一个整点数。另外,虽然一天有24小时,钟却是只在后半天敲1~12下。
例如在23:00敲钟,就是“当当当当当当当当当当当”,而到了23:01就会是“当当当当当当当当当当当当”。在午夜00:00到中午12:00期间(端点时间包括在内),笨钟是不敲的。下面就请你写个程序,根据当前时间替大笨钟敲钟。
输入格式:
输入第一行按照hh:mm的格式给出当前时间。其中hh是小时,在00到23之间;mm是分钟,在00到59之间。
输出格式:
根据当前时间替大笨钟敲钟,即在一行中输出相应数量个Dang。如果不是敲钟期,则输出:Only hh:mm. Too early to Dang.
其中hh:mm是输入的时间。
输入样例1:

19:05

输出样例1:

DangDangDangDangDangDangDangDang

输入样例2:

07:05

输出样例2:

Only 07:05. Too early to Dang.

#include<stdio.h>
int main()
{
 int hour,minute,i;
 scanf("%d:%d",&hour,&minute);
 if(hour <= 12){
  printf("Only %02d:%02d.  Too early to Dang.",hour,minute);
 }else{
  if(minute == 0){
   for(i = 1; i <= hour - 12; i++){
    printf("Dang");
   }
  }else{
   for(i = 1; i <= hour - 11; i++){
    printf("Dang");
   }
  }
 }
 return 0;
}
  • 5
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值