C_练习题0_是男人就练一百题

友情提示:转载请标明出处哦~
建议练习每一道题的时候都要限时练习~
练习所用编译器:VisualC++2010学习版


练习记录:
2020/11/21 两题

Question 1 (循环-选择)

题目:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?

程序分析:可填在百位、十位、个位的数字都是1、2、3、4。组成所有的排列后再去 掉不满足条件的排列。

//题目:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?
//
//程序分析:可填在百位、十位、个位的数字都是1、2、3、4。组成所有的排列后再去 掉不满足条件的排列。

//用时:8min
#include <stdio.h>

int main()
{
	int sum;
	int x =1,y=2,z=3;
	for(x=1;x<5;x++)//百位
		{
			for(y=1;y<5;y++)//十位
			{
				if(x ==y )continue;
				for(z=1;z<5;z++)//个位
				{
					if((z==y)||(z==x))continue;
					sum = z+y*10+x*100;
					printf("%d\n",sum);
				}
			}
		}	
}

Question 2 (选择-double/float)

题目:企业发放的奖金根据利润提成。

利润(I)低于或等于10万元时,奖金可提10%;
利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提成7.5%;
20万到40万之间时,高于20万元的部分,可提成5%;
40万到60万之间时高于40万元的部分,可提成3%;
60万到100万之间时,高于60万元的部分,可提成1.5%;
高于100万元时,超过100万元的部分按1%提成。
从键盘输入当月利润I,求应发放奖金总数?

程序分析:请利用数轴来分界,定位。注意定义时需把奖金定义成长整型。

//题目:企业发放的奖金根据利润提成。
//
//利润(I)低于或等于10万元时,奖金可提10%;
//利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提成7.5%;
//20万到40万之间时,高于20万元的部分,可提成5%;
//40万到60万之间时高于40万元的部分,可提成3%;
//60万到100万之间时,高于60万元的部分,可提成1.5%;
//高于100万元时,超过100万元的部分按1%提成。
//从键盘输入当月利润I,求应发放奖金总数?
//
//程序分析:请利用数轴来分界,定位。注意定义时需把奖金定义成长整型。

#include <stdio.h>
#include <conio.h>
int main()
{
	double I,G = 0;
	printf("请输入当月利润:");
	scanf("%lf",&I);
//	printf("%f",I);		
	if(I<=10)
		G = I*0.1;
	else if(I>10&&I<=20)
		G = 1+(I-10)*0.075;
	else if(I>20&&I<=40)
		G = 1+0.75+(I-20)*0.05;
	else if(I>40&&I<=60)
		G = 1+0.75+20*0.05+(I-40)*0.03;
	else if(I>60&&I<=100)
		G = 1+0.75+20*0.05+20*0.03+(I-60)*0.015;
	else if(I>=100)
		G = 1+0.75+20*0.05+20*0.03+40*0.015+(I-100)*0.01;
	else
		printf("出大问题了");
	printf("%lf",G*10000);
} 
  1. 对if和输出字符复习
    double-%lf
    float-%f

Question 3 (数学分析运算-math.h)

题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?

程序分析:

假设该数为 x。

1、则:x + 100 = n2, x + 100 + 168 = m2

2、计算等式:m2 - n2 = (m + n)(m - n) = 168

3、设置: m + n = i,m - n = j,i * j =168,i 和 j 至少一个是偶数
4、可得: m = (i + j) / 2, n = (i - j) / 2,i 和 j 要么都是偶数,要么都是奇数。

5、从 3 和 4 推导可知道,i 与 j 均是大于等于 2 的偶数。

6、由于 i * j = 168, j>=2,则 1 < i < 168 / 2 + 1。

7、接下来将 i 的所有数字循环计算即可。

具体实现如下:

//题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?
//程序分析:
//假设该数为 x。
//1、则:x + 100 = n2, x + 100 + 168 = m2
//2、计算等式:m2 - n2 = (m + n)(m - n) = 168
//3、设置: m + n = i,m - n = j,i * j = 168,i 和 j 至少一个是偶数
//4、可得: m = (i + j) / 2, n = (i - j) / 2,i 和 j 要么都是偶数,要么都是奇数。
//5、从 3 和 4 推导可知道,i 与 j 均是大于等于 2 的偶数。
//6、由于 i * j = 168, j >= 2,则 1 < i < 168 / 2 + 1。
//	7、接下来将 i 的所有数字循环计算即可。
//	具体实现如下:
#include <stdio.h>

int main()
{
	int i, j, x, m, n;
	for(i=1;i<85;i++)
		if (168 % i == 0)
		{
			j = 168 / i;
			if (i > j && (i + j) % 2 == 0 && (i - j) % 2 == 0)
			{
				m = (i + j) / 2;
				n = (i - j) / 2;
				x = n * n - 100;
				printf("%d + 100 = %d * %d\n", x, n, n);
				printf("%d + 268 = %d * %d\n", x, m, m);
			}
		}
	return 0;
}

Question 4 (闰年-选择)

题目:输入某年某月某日,判断这一天是这一年的第几天?

程序分析:以3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的第几天,特殊情况,闰年且输入月份大于3时需考虑多加一天。

#include <stdio.h>
#define   _CRT_SECURE_NO_WARNINGS
#pragma once
int main()
{
	int Y, M, D;
	int sum,leap;
	printf("请输入年月日:");
	scanf("%d%d%d", &Y, &M, &D);
	switch (M)
	{
	case 1:sum = 0; break;
	case 2:sum = 31; break;
	case 3:sum = 59; break;//默认为闰年,之后再判断到底是不是闰年,如果是闰年就+1
	case 4:sum = 90; break;
	case 5:sum = 120; break;
	case 6:sum = 151; break;
	case 7:sum = 181; break;
	case 8:sum = 212; break;
	case 9:sum = 243; break;
	case 10:sum = 273; break;
	case 11:sum = 304; break;
	case 12:sum = 334; break;
	}
	sum = sum + D;
	if (Y % 400 == 0 || (Y % 4 == 0 && Y % 100 != 0))
		leap = 1;
	else {
		leap = 0;
	}
	if (leap == 1 && M > 2)
		sum++;
	printf("这是这一年的第%d天", sum);
	return 0;
}

Question 5 ()

题目:输入三个整数x,y,z,请把这三个数由小到大输出。

程序分析:我们想办法把最小的数放到x上,先将x与y进行比较,如果x>y则将x与y的值进行交换,然后再用x与z进行比较,如果x>z则将x与z的值进行交换,这样能使x最小。


//题目:输入三个整数x,y,z,请把这三个数由小到大输出。

//程序分析:我们想办法把最小的数放到x上,先将x与y进行比较,
//如果x>y则将x与y的值进行交换,然后再用x与z进行比较,如果x>z则将x与z的值进行交换,这样能使x最小。`
#include <stdio.h>
int funCompare(int x,int y);
int main()
{
	int i,j,k,p;
	printf("请输入三个数:");
	scanf("%d%d%d",&i,&j,&k);
	//1.编写一个两个比较函数
	//2.直接两个数之间比较
	
	//1
	p = funCompare(funCompare(i,j),k);
	printf("%d",p);
	 
	return 0;
}
int funCompare(int x,int y)
{
	if(x>y)
	return x;
	else
	return y;
}

Question 6 (※)

题目:用*号输出字母C的图案。

程序分析:可先用’*'号在纸上写出字母C,再分行输出。

//题目:用*号输出字母C的图案。

//程序分析:可先用'*'号在纸上写出字母C,再分行输出。

#include <stdio.h>

int main()
{
	printf("***\n");
	printf("*\n");
	printf("***");
	return 0;
}

Question 7 (搬运)

题目:输出特殊图案,请在c环境中运行,看一看,Very Beautiful!

程序分析:字符共有256个。不同字符,图形不一样。

VC6.0下出现中文乱码(原因+解决方法):
176的16进制是B0,219的16进制是DB,0xB0DB是"佰"字的内码,所以输出的就是"佰"了。
主要原因是文件信息的代码页不同,我们所使用的操作系统中文状态下的代码页,要显示扩展的ASCII码需要在437 OEM-美国这个下面显示,这样就可以显示出你所希望的。具体修改控制台的默认代码页步骤如下:
1.点击运行界面左上角标题栏图标【c:\】,选择默认值一项
2.修改默认代码页,936(ANSI/OEM-简体中文GBK)为437 OEM-美国
3、关闭后重新运行一下即可

#include<stdio.h>
int main()
{
    char a=176,b=219;
    printf("%c%c%c%c%c\n",b,a,a,a,b);
    printf("%c%c%c%c%c\n",a,b,a,b,a);
    printf("%c%c%c%c%c\n",a,a,b,a,a);
    printf("%c%c%c%c%c\n",a,b,a,b,a);
    printf("%c%c%c%c%c\n",b,a,a,a,b);
    return 0;
}

Question 8 ()

题目:输出9*9口诀。

程序分析:分行与列考虑,共 9 行 9 列,i 控制行,j 控制列

//题目:输出9*9口诀。

//程序分析:分行与列考虑,共 9 行 9 列,i 控制行,j 控制列 

#include <stdio.h>

int main()
{
	int i,j;
	for(i=1;i<10;i++)
		{
		    for(j=1;j<=i;j++)
			printf("%d * %d = %d ",i,j,i*j);
			printf("\n");
		}
	return 0;
}
}

Question 9 ()

题目:要求输出国际象棋棋盘。

程序分析:国际象棋棋盘由64个黑白相间的格子组成,分为8行*8列。用i控制行,j来控制列,根据i+j的和的变化来控制输出黑方格,还是白方格。

如果出现乱码情况请参考本博客【C 练习实例7】的解决方法。

//题目:要求输出国际象棋棋盘。

//程序分析:国际象棋棋盘由64个黑白相间的格子组成,分为8行*8列。用i控制行,j来控制列,
//根据i+j的和的变化来控制输出黑方格,还是白方格。

//如果出现乱码情况请参考本博客【C 练习实例7】的解决方法。
#include <stdio.h>

int main()
{
	int i,j;
	for(i=0;i<8;i++)
		{
		for(j=0;j<8;j++)
		if((i+j)%2 == 0)
			printf("**");
		else
			printf("  ");
		printf("\n");
		}
	return 0;
}

Question 10 ()

题目:打印楼梯,同时在楼梯上方打印两个笑脸。

程序分析:用 ASCII 1 来输出笑脸;用i控制行,j来控制列,j根据i的变化来控制输出黑方格的个数。

如果出现乱码情况请参考【C 练习实例7】的解决方法。

//题目:打印楼梯,同时在楼梯上方打印两个笑脸。

//程序分析:用 ASCII 1 来输出笑脸;用i控制行,j来控制列,j根据i的变化来控制输出黑方格的个数。

#include <stdio.h>

int main()
{
	int i,j;
	printf("\1\1\n"); /*输出两个笑脸*/
	for(i=0;i<5;i++)
	{
		for(j=0;j<5;j++)
			{
				if(i>=j)	
				printf("*");
				else
				printf(" ");
			}
		printf("\n");	
	}
		
	return 0;
	
}	
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值