说明:简单模拟题是“题目怎么说,你就怎么做”的题目,考察基本代码能力。
害死人不偿命的(3n+1)猜想
- 题目描述:卡拉兹猜想,对于任何一个自然数n,如果是偶数,就砍掉一半;如果是奇数,就将(3n+1)砍掉一半,一直到最后一步得到n=1。给定一个不超过1000的正整数n,需要多少步才能得到n=1?
- 代码code:
#include <stdio.h>
int main()
{
int n,count;
scanf("%d",&n);
while(n!= 1)
{
if(n%2 == 0) n = n/2;
else n = (3*n+1)/2;
count++;
}
printf("%d\n",count);
return 0;
}
挖掘机技术哪家强
- 题目描述:挖掘机技能大赛,在第一行输入一个不超过100000正整数N,即参赛人数,随后的N行,每行给出参赛者的信息和成绩,包括其代表的学校编号(从1开始连续编号)及其总分,中间空格分隔。
- 代码code:
#include <stdio.h>
const int maxN = 100000;
int school[maxN] = {0};
int main()
{
int N,schoolID,score;
scanf("%d",&N);
for(int i=0;i<N;i++)
{
scanf("%d %d",&schoolID,&score);
school[schoolID] += score;
}
int MAX,k = 0;
for(int i=1;i<=N;i++)
{
if(school[i]>MAX)
{
MAX = school[i];
k = i;
}
}
printf("%d %d",k,MAX);
return 0;
}
找X
- 题目描述:输入一个正整数n(1=<n<=200),在输入n个数值不同的数,在输入一个X,输出X在这个数列的下标。
- 代码code:
#include <stdio.h>
const int maxn = 200;
int main()
{
int n;
int a[maxn] = {0};
scanf("%d",&n);
for(int i=0;i<n;i++)
{
scanf("%d",&a[i]);
}
int x,index;
scanf("%d",&x);
for(int k=0;k<n;k++)
{
if(a[k] == x)
{
index = k;
}
}
printf("%d\n",index);
return 0;
}
跟奥巴马一起学编程
- 题目描述:奥巴马编写了一个计算机程序,在一行中给定正方形边长N 和填充字符C,间隔一个空格,输出行数是列数的一半。
- 代码code:
#include <stdio.h>
int main()
{
int row,col;
char C;
scanf("%d %c",&col,&C);
if(col%2 == 1) row = col / 2 + 1;
else row = col /2;
for(int i=0;i<col;i++)
{
printf("%c",C);
}
printf("\n");
for(int k=2;k<row;k++)
{
printf("%c",C);
for(int j=0;j<col-2;j++)
{
printf(" ");
}
printf("%c\n",C);
}
for(int i=0;i<col;i++)
{
printf("%c",C);
}
return 0;
}
日期差值
- 题目描述:有两个日期,求两个日期 之间的天数,如果两个日期是连续的,则规定他们之间的天数为两天。每组数据有两行输入。
- 代码code:
#include <stdio.h>
int month[13][2] = {{0,0},{31,31},{28,29},{31,31},{30,30},{31,31},{30,30},{31,31},{31,31},{30,30},{31,31},{30,30},{31,31}};
bool isLeap(int year)
{
return((year % 4 == 0&&year % 100 != 0)||(year%400 ==0));
}
int main()
{
int time1,y1,m1,d1;
int time2,y2,m2,d2;
while(scanf("%d%d",&time1,&time2)!= EOF)
{
if(time1 > time2)
{
int temp = time1;
time2 = time1;
time1 = temp;
}
y1 = time1 / 10000,m1 = time1 % 10000 / 100,d1 = time1 % 100;
y2 = time2 / 10000,m2 = time2 % 10000 / 100,d2 = time2 % 100;
int ans = 1;
while(y1<y2||m1<m2||d1<d2)
{
d1++;
if(d1 == month[m1][isLeap(y1)]+1)
{
m1++;
d1 = 1;
}
if(m1 == 13)
{
y1++;
m1 = 1;
}
ans++;
}
printf("%d\n",ans);
}
return 0;
}
D进制的A+B
- 题目描述:输入两个非负十进制整数A和B以及D进制数,输出A+B的D进制数。
- 代码code:
#include <stdio.h>
int main()
{
int a,b,d;
scanf("%d%d%d",&a,&b,&d);
int sum = a + b;
int ans[31],num = 0;
do{
ans[num++] = sum % d;
sum /= d;
}while(sum!=0);
for(int i = num-1;i>=0;i--)
{
printf("%d",ans[i]);
}
return 0;
}
回文串
- 题目描述:读入一串字符,判断是否为回文串。“回文串”为正读和反读都一样的字符串,也可说是轴对称。长不超过255的字符串,是回文串输出YES,否则输出NO。
#include <cstdio>
#include<cstring>
const int maxn = 255;
bool judge(char str[])
{
int len = strlen(str);
for(int i=0;i<len/2;i++)
{
if(str[i] != str[len - i -1])
{
return false;
}
}
return true;
}
int main()
{
char str[maxn];
while(gets(str))
{
bool flag = judge(str);
if(flag == true)
{
printf("YES\n");
}
else
{
printf("NO\n");
}
}
return 0;
}
说反话
- 题目描述:给定一句英语字符串,将所有单词颠倒顺序输出。
- 代码code:
#include <cstdio>
#include<cstring>
int main()
{
char str[90];
gets(str);
int len = strlen(str),r=0,h=0;
char ans[90][90];
for(int i=0;i<len;i++)
{
if(str[i]!=' ')
{
ans[r][h++] = str[i];
}
else
{
ans[r][h] = '\0';
r++;
h = 0;
}
}
for(int i=r;i>=0;i--)
{
printf("%s",ans[i]);
if(i>0) printf(" ");
}
return 0;
}