PAT乙级C/C++简单模拟题


说明:简单模拟题是“题目怎么说,你就怎么做”的题目,考察基本代码能力。

害死人不偿命的(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;	
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章