蓝基(2 1 12 11 10)

咳咳,今天终于想起我亲爱的博客了,我要好好写,对得起我吹的牛逼。蓝桥杯很快就要到了,寒假实在是没干什么有用的。以后每天起码抽一个小时敲代码吧,并且每天写博客记录,GTMD。

1.01字符
问题描述

对于长度为5位的一个01串,每一位都可能是0或1,一共有32种可能。它们的前几个是:

00000

00001

00010

00011

00100

请按从小到大的顺序输出这32种01串。

输入格式
本试题没有输入。
输出格式
输出32行,按从小到大的顺序每行一个长度为5的01串。
样例输出
00000
00001
00010
00011
<以下部分省略>

#include <stdio.h>
int main (void)
{
	int n,i,j,k,s;
	int a[10];
	for (s=0;s<5;s++)
		a[s]=0;
	for (k=0;k<32;k++)
	{
		for (i=0;i<5;i++)
			{
				printf ("%d",a[i]);
			}
		if (k!=31)
			printf ("\n");
		n=4;
		a[n]=a[n]+1;
		if (a[n]==2)
			{
				for (j=1;a[n]==2;n--)
				{
					a[n]=0;
					a[n-1]=a[n-1]+1;
				}
			}

	}
	return 0;	
} 

2.闰年判断

问题描述

给定一个年份,判断这一年是不是闰年。

当以下情况之一满足时,这一年是闰年:

1. 年份是4的倍数而不是100的倍数;

2. 年份是400的倍数。

其他的年份都不是闰年。

输入格式
输入包含一个整数y,表示当前的年份。
输出格式
输出一行,如果给定的年份是闰年,则输出yes,否则输出no。

说明:当试题指定你输出一个字符串作为结果(比如本题的yes或者no,你需要严格按照试题中给定的大小写,写错大小写将不得分。

样例输入
2013
样例输出
no
样例输入
2016
样例输出
yes
数据规模与约定
1990 <= y <= 2050。

#include<stdio.h>
int main (void)
{
	int y,x;
	scanf("%d",&y);
	if (y%400==0)
		printf ("yes\n");
	else
		{
			if (y%4==0&&y%100!=0)//或|| 且&& 
			{
				printf ("yes\n");
			}
			else
			{
				printf ("no\n");
			}
		}
		return 0;
}

3.16转八

问题描述
  给定n个十六进制正整数,输出它们对应的八进制数。

输入格式
  输入的第一行为一个正整数n (1<=n<=10)。
  接下来n行,每行一个由0~9、大写字母A~F组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。

输出格式
  输出n行,每行为输入对应的八进制正整数。

  【注意
  输入的十六进制数不会有前导0,比如012A。
  输出的八进制数也不能有前导0。

样例输入
  2
  39
  123ABC

样例输出
  71
  4435274

  提示

  先将十六进制数转换成某进制数,再由某进制数转换成八进制。

#include <iostream>
using namespace std;
int main()
{
int n=0; //记录输入数据的个数
cin>>n;

string sixTeen[10];  //用来记录输入的数据

for(int i=0;i<n;i++)
{
cin>>sixTeen[i];
}


for(int i=0;i<n;i++)
{
string eight;//记录八进制数据
string tow; //记录二进制数据
char eig;

//转换为二进制
for(int j=0;j<sixTeen[i].length();j++)
{
switch(sixTeen[i][j])
{
case '0':tow+="0000";break;
                case '1':tow+="0001";break;
                case '2':tow+="0010";break;
                case '3':tow+="0011";break;
                case '4':tow+="0100";break;
                case '5':tow+="0101";break;
                case '6':tow+="0110";break;
                case '7':tow+="0111";break;
                case '8':tow+="1000";break;
                case '9':tow+="1001";break;
                case 'A':tow+="1010";break;
                case 'B':tow+="1011";break;
                case 'C':tow+="1100";break;
                case 'D':tow+="1101";break;
                case 'E':tow+="1110";break;
                case 'F':tow+="1111";break;
                default:break;
}

}

//转换为八进制
//首先补齐“0”
int m=tow.length()%3;
if(m==1)
tow.insert(0,"00");
else if(m==2)
tow.insert(0,"0");
//进行转换
if(!(tow[0]=='0'&&tow[1]=='0'&&tow[2]=='0'))
{
eig=(tow[0]-'0')*4+(tow[1]-'0')*2+(tow[2]);
eight=eight+eig;
}

for(int k=3;k<tow.length();k=k+3)
{
//eig=(tow[k*3]-'0')*4+(tow[k*3+1]-'0')*2+(tow[k*3+2]);
//eight=eight+eig;

if(tow.substr(k,3)=="000")
eight+="0";
else if(tow.substr(k,3)=="001")
eight+="1";
else if(tow.substr(k,3)=="010")
eight+="2";
else if(tow.substr(k,3)=="011")
eight+="3";
else if(tow.substr(k,3)=="100")
eight+="4";
else if(tow.substr(k,3)=="101")
eight+="5";
else if(tow.substr(k,3)=="110")
eight+="6";
else if(tow.substr(k,3)=="111")
eight+="7";

}

//输出最终的八进制数
cout<<eight<<endl;
}

return 0;
}

1.不是很懂 先贴着。。。。

4.16转10

问题描述
  从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出。
  注:十六进制数中的10~15分别用大写的英文字母A、B、C、D、E、F表示。
样例输入
FFFF
样例输出
65535

#include <stdio.h>  
#include <string.h>  
#include <math.h>  
int main(void)  
	{  
    char strHex[8];  
    int i = 0, len = 0, temp = 0;  
    __int64 nDec = 0;  //- Int64是有符号 64 位整数数据类型

    gets(strHex);  

    len = strlen(strHex);  
    for (i = 0; strHex[i] != '\0'; i++)  
    {  
        switch(strHex[i])  
        {  
        case 'A': temp = 10; break;  
        case 'B': temp = 11; break;  
        case 'C': temp = 12; break;  
        case 'D': temp = 13; break;  
        case 'E': temp = 14; break;  
        case 'F': temp = 15; break;  
        default: temp = strHex[i]-'0';
			 break;  
        }  
        nDec += (temp*pow(16,len-1-i));  //16的几次方 
    }  
    printf("%I64d",nDec);  
    return 0;  
}  

4.10转6

问题描述
  十六进制数是在程序设计时经常要使用到的一种整数的表示方式。它有0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F共16个符号,分别表示十进制数的0至15。十六进制的计数方法是满16进1,所以十进制数16在十六进制中是10,而十进制的17在十六进制中是11,以此类推,十进制的30在十六进制中是1E。
  给出一个非负整数,将它表示成十六进制的形式。
输入格式
  输入包含一个非负整数a,表示要转换的数。0<=a<=2147483647
输出格式
  输出这个整数的16进制表示
样例输入
30
样例输出
1E

#include<stdio.h>  
int main()  
{  
    int n;  
    scanf("%d",&n);  
    printf("%X\n",n);  
    return 0;  
}  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值