您的位置:首页 > 其它

蓝基(2 1 12 11 10)

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

1.01字符问题描述对于长度为5位的一个01串,每一位都可能是0或1,一共有32种可能。它们的前几个是:0000000001000100001100100请按从小到大的顺序输出这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
=a
+1;
if (a
==2)
{
for (j=1;a
==2;n--)
{
a
=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;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐