C语言编程PAT乙级学习笔记示例分享

目录
  • 1001 害死人不偿命的(3n+1)猜想
  • 1002 写出这个数
  • 1003 我要通过!
  • 1004 成绩排名
  • 1005 继续(3n+1)猜想
  • 1006 换个格式输出整数
  • 1007 素数对猜想问题
  • 1008 数组元素循环右移问题
  • 1009 说反话
  • 1010 一元多项式求导
  • 1011 A+B 和 C
  • 1012 数字分类
  • 1013 数素数
  • 1014 福尔摩斯的约会

1001 害死人不偿命的(3n+1)猜想

#include<iostream>
#include<stack>
using namespace std;
int main()
{
	int n,count=0;
	cin>>n;
	while(n!=1){
		if(n%2==0)n=n/2;
		else n=(3*n+1)/2;
		count++;
	}
	cout<<count;
	system("pause");
	return 0;
}

1002 写出这个数

#include<iostream>
#include<stack>
using namespace std;
int main()
{
	string str;
	cin>>str;
	int sum=0;
	bool start =true;
	for(int i=0;i<str.length();i++){
		sum+=(str[i]-'0');
	}
	stack<int> sta;
	while(sum!=0){
		sta.push(sum%10);
		sum=sum/10;
	}
	while(!sta.empty()){
		if(start)start=false;
		else cout<<" ";
		int tmp=sta.top();
		sta.pop();
		switch(tmp){
			case 0:cout<<"ling";break;
			case 1:cout<<"yi";break;
			case 2:cout<<"er";break;
			case 3:cout<<"san";break;
			case 4:cout<<"si";break;
			case 5:cout<<"wu";break;
			case 6:cout<<"liu";break;
			case 7:cout<<"qi";break;
			case 8:cout<<"ba";break;
			case 9:cout<<"jiu";break;
		}
	}
	system("pause");
	return 0;
}

1003 我要通过!

//左边a的个数*中间=右边
#include<iostream>
using namespace std;
int main()
{
	int n;
	cin>>n;
	while(n--){
		string c;
		cin>>c;
		int count1=0,count2=0,count3=0,judge=0;
		bool result=true;
		for(int i=0;i<c.length();i++){
			if(c[i]=='P'||c[i]=='A'||c[i]=='T'){
				if(judge==0&&c[i]=='A')count1++;
				else if(judge==0&&c[i]=='P')judge=1;
				else if(judge==1&&c[i]=='A')count2++;
				else if(judge==1&&c[i]=='T')judge=2;
				else if(judge==2&&c[i]=='A')count3++;
				else result=false;
			}
			else{
				result=false;
				break;
			}
		}
		if(judge!=2||count1*count2!=count3||count2==0)result=false;
		if(result)cout<<"YES"<<endl;
		else cout<<"NO"<<endl;
	}
	return 0;
}

1004 成绩排名

#include<iostream>
using namespace std;
typedef struct student{
	string name;
	string num;
	int score;
}Student;
int main()
{
	int n;
	cin>>n;
	struct student stu[n];
	for(int i=0;i<n;i++){
		cin>>stu[i].name;
		cin>>stu[i].num;
		cin>>stu[i].score;
	}
	struct student min=stu[0];
	struct student max=stu[0];
	for(int i=1;i<n;i++){
		if(stu[i].score>max.score)max=stu[i];
		if(stu[i].score<min.score)min=stu[i];
	}
	cout<<max.name<<" "<<max.num<<endl;
	cout<<min.name<<" "<<min.num<<endl;
	return 0;
}

1005 继续(3n+1)猜想

#include<iostream>
using namespace std;
int main()
{
	int n;
	int num[101]={0};
	cin>>n;
	for(int i=0;i<n;i++){
		int tmp;
		cin>>tmp;
		num[tmp]=1;
	}
	for(int i=0;i<101;i++){
		if(num[i]==1){
			int temp=i;
			while(temp>1){
				if(temp%2==0)temp/=2;
				else temp=(3*temp+1)/2;
				if(temp!=1&&temp<101)num[temp]=0;
			}
		}
	}
	int flag=1;
	for(int i=100;i>=0;i--){
		if(num[i]==1){
			if(flag==0){
				cout<<" "<<i;
			}
			else{
				flag=0;
				cout<<i;
			}
		}
	}
	return 0;
}

1006 换个格式输出整数

#include<iostream>
using namespace std;
int main()
{
	int n;
	cin>>n;
	int a,b,c;
	a=n/100;
	b=n%100/10;
	c=n%10;
	while(a!=0){
		cout<<"B";
		a--;
	}
	while(b!=0){
		cout<<"S";
		b--;
	}
	for(int i=0;i<c;i++){
		cout<<i+1;
	}
	return 0;
}

1007 素数对猜想问题

#include<iostream>
#include<vector>
#include<math.h>
using namespace std;
int main()
{
	int n,i,j;
	cin>>n;
	int count=0;
	vector<int> prime;
	for(int i=2;i<=n;i++){
		for(j=2;j<=sqrt(i);j++){
			if(i%j==0)break;
		}
		if(j>sqrt(i))
			prime.push_back(i);
	}
	for(int i=1;i<prime.size();i++)
		if(prime[i]-prime[i-1]==2)count++;
		cout<<count;
	return 0;
}

1008 数组元素循环右移问题

#include<iostream>
using namespace std;
//change函数
void change(int a[],int l,int r){
	for(int i=l;i<=(l+r)/2;i++){
		int tmp=a[i];
		a[i]=a[l+r-i];
		a[l+r-i]=tmp;
	}
}
int main()
{
	int m,n;
	cin>>m>>n;
	n%=m;//考虑当需要循环的次数超过了数列总数时的情况!!!
	int a[m]={0};
	for(int i=0;i<m;i++){
		cin>>a[i];
	}
	change(a,0,m-1-n);
	change(a,m-n,m-1);
	change(a,0,m-1);
	int count=1;
	for(int i=0;i<m;i++){
		if(count==1){
			cout<<a[i];
			count=0;
		}
		else{
			count=0;
			cout<<" "<<a[i];
		}
	}
}

1009 说反话

#include<iostream>
using namespace std;
int main()
{
    string str[80];
    int i=0,j;
    while(cin>>str[i]){//这个会经常使用,要记住啊。
        i++;
    }
    for(j=i-1;j>=0;j--){
        if(j!=i-1)cout<<" ";
        cout<<str[j];
    }
    return 0;
}

1010 一元多项式求导

#include<iostream>
using namespace std;
int main()
{
	int a[1000];
    int i=0;
    int m,n;
    while(cin>>m>>n){
        a[i]=m*n;
        a[i+1]=n-1;
        if(a[i]==0&&a[i+1]==-1)continue;
        else i+=2;
    }
    for(int j=0;j<i;j++){
        if(j!=0){
            cout<<" ";
        }
        cout<<a[j];
    }
    if(i<1)cout<<"0 0";//注意“零多项式”的指数和系数都是 0,但是表示为0 0.
    return 0;
}

1011 A+B 和 C

#include<iostream>
using namespace std;
int main()
{
    int n;
    cin>>n;
    int i=0;
    while(n--){
        i++;
        double a,b,c;//看测试用例,选用double或者float类型
        cin>>a>>b>>c;
        if(a+b>c)cout<<"Case #"<<i<<": true"<<endl;
        else cout<<"Case #"<<i<<": false"<<endl;
    }
    return 0;
}

1012 数字分类

#include<iostream>
#include<stdio.h>
using namespace std;
int main()
{
    int n,i;
    cin>>n;
    int a[1001];
    int sum1=0,flag=1,sum2=0,count1=0,count2=0,count3=0,max=0;
    double sum3=0;
    for(i=0;i<n;i++){
        cin>>a[i];
        if(a[i]%2==0&&a[i]%5==0){
            sum1+=a[i];
        }
        else if(a[i]%5==1){
            sum2=sum2+flag*a[i];
            flag=flag*(-1);
            count2++;
        }
        else if(a[i]%5==2){
            count1++;
        }
        else if(a[i]%5==3){
            sum3+=a[i];
            count3++;
        }
        else if(a[i]%5==4){
            if(a[i]>max)max=a[i];
        }
    }
    if(sum1==0)cout<<"N ";
    else cout<<sum1<<" ";
    if(count2==0)cout<<"N ";
    else cout<<sum2<<" ";
    if(count1==0)cout<<"N ";
    else cout<<count1<<" ";
    if(count3==0)cout<<"N ";
    else printf("%.1lf ",sum3/count3);
    if(max==0)cout<<"N";
    else cout<<max;
    return 0;
}

1013 数素数

#include<iostream>
#include<cmath>
using namespace std;
bool isprime(int n){
    int i;
    if(n==2){
        return true;
    }
    else if(n<=1){
        return false;
    }
    else{
        for(i=2;i<=sqrt(n);i++){//要用平方根,如果用n/2找素数,会显示一个错误,表示代码运算量过大。
            if(n%i==0)return false;
        }
        if(i>sqrt(n))return true;
        else return false;
    }
}
int main()
{
    int m,n;
    cin>>m>>n;
    int a[110000]={0};
    int x=1;
    for(int i=1;i<110000;i++){
        if(isprime(i)){
            a[x]=i;
            x++;
        }
    }
    int count=0;
    for(int i=m;i<=n;i++){
        count++;
        count=count%10;
        if(count==1)cout<<a[i];
        else cout<<" "<<a[i];
        if(count==0)cout<<endl;
    }
    return 0;
}

1014 福尔摩斯的约会

#include<iostream>
#include<string>
#include<cstdio>
using namespace std;
int main()
{
    string s1,s2,s3,s4;
    cin>>s1>>s2>>s3>>s4;
    int len1=s1.length()<s1.length()?s1.length():s2.length();
    int len2=s3.length()<s4.length()?s3.length():s4.length();
    char weekday,hour;
    int minute,flag=0;
    for(int i=0;i<len1;i++){
        if(s1[i]==s2[i]&&flag==0&&(s1[i]>='A'&&s1[i]<='G')){
            weekday=s1[i];
            flag=1;
            switch(weekday){
                case 'A':cout<<"MON ";break;
                case 'B':cout<<"TUE ";break;
                case 'C':cout<<"WED ";break;
                case 'D':cout<<"THU ";break;
                case 'E':cout<<"FRI ";break;
                case 'F':cout<<"SAT ";break;
                case 'G':cout<<"SUN ";break;
            }
            continue;//必不可少,保证下一步的if语句可以执行。不使用continue的话,可以把两个if语句的执行顺序调换一下。
        }
        if(s1[i]==s2[i]&&flag==1&&((s1[i]>='A' && s1[i]<='N') || (s1[i] >= '0' && s1[i] <= '9'))){
            hour=s1[i];
            break;
        }
    }
    for(int i=0;i<len2;i++){
        if(s3[i]==s4[i]&&isalpha(s3[i])){
            minute=i;
            break;
        }
    }
    if(hour>='0'&&hour<='9'){
        cout<<'0'<<hour;
    }else{
        cout<<hour-'A'+10;
    }
    printf(":%02d", minute);
    return 0;
}

以上就是C语言编程PAT乙级学习笔记实现示例的详细内容,更多关于C语言PAT乙级的资料请关注我们其它相关文章!

(0)

相关推荐

  • C语言编程PAT乙级学习笔记示例分享

    目录 1001 害死人不偿命的(3n+1)猜想 1002 写出这个数 1003 我要通过! 1004 成绩排名 1005 继续(3n+1)猜想 1006 换个格式输出整数 1007 素数对猜想问题 1008 数组元素循环右移问题 1009 说反话 1010 一元多项式求导 1011 A+B 和 C 1012 数字分类 1013 数素数 1014 福尔摩斯的约会 1001 害死人不偿命的(3n+1)猜想 #include<iostream> #include<stack> using

  • Java语言Consistent Hash算法学习笔记(代码示例)

    本文研究的主要是ConsistentHashing算法代码. 一致性哈希(Consistent Hash) 协议简介 一致性哈希算法在1997年由麻省理工学院提出(参见0),设计目标是为了解决因特网中的热点(Hot pot)问题,初衷和CARP十分类似.一致性哈希修正了CARP使用的简单哈希算法带来的问题,使得DHT可以在P2P环境中真正得到应用. 哈希算法 一致性哈希提出了在动态变化的Cache环境中,哈希算法应该满足的4个适应条件: 平衡性(Balance) 平衡性是指哈希的结果能够尽可能分

  • C语言编程C++动态内存分配示例讲解

    目录 动态内存管理 为什么存在动态内存分配 动态内存函数的介绍 malloc申请空间和free释放空间 有借有还 free释放内存 calloc申请内存 realloc调整动态内存的大小 realloc使用的注意事项 当然realloc也可以直接开辟空间 常见的动态内存错误 1.对NULL指针的解引用操作 2.对动态开辟空间的越界访问 3.对非动态开辟内存使用free释放 4.使用free释放一块动态内存开辟的一部分 5.对同一块动态内存多次释放 6.动态开辟内存忘记释放(内存泄漏) 几个面试题

  • C语言编程入门必背的示例代码整理大全

    目录 一.C语言必背代码前言 二.一部分C语言必背代码 一.C语言必背代码前言 对于c语言来说,要记得东西其实不多,基本就是几个常用语句加一些关键字而已.你所看到的那些几千甚至上万行的代码,都是用这些语句和关键词来重复编写的.只是他们逻辑功能不一样,那如何快速的上手C语言代码,建议多看多写,下面是小编整理的C语言必背代码. 二.一部分C语言必背代码 1.输出9*9成法口诀,共9行9列,i控制行,j控制列. #include "stdio.h" main() {int i,j,resul

  • C语言编程C++柔性数组结构示例讲解

    目录 绕指柔-柔性数组 柔性数组的特点: 第一个好处是:方便内存释放 第二个好处是:这样有利于访问速度 总结 绕指柔-柔性数组 也许你从来没有听说过柔性数组(flexible array)这个概念,但是它确实是存在的. C99 中,结构体中的最后一个元素允许是未知大小的数组,这就叫做柔性数组成员. 柔性数组的特点: 1.结构中的柔性数组成员前面必须至少一个其他成员. 2.sizeof 返回的这种结构大小不包括柔性数组的内存. 3.包含柔性数组成员的结构用malloc ()函数进行内存的动态分配,

  • C语言一维数组初步学习笔记

    数组 可以存储一组或者多组数值的变量,里面包含多个元素,数组的每个成员都是一个数组元素. 一维数组 定义:类型 数组名[常量表达式] = {值1, 值2, 值3-}; int a[3] = {0, 1, 2}; float f[2] = {1.2, 2.3, 3.14}; char str[] = {'h', 'e', 'l', 'l', 'o'}; chat str1 = "iPhone";//这也是定义字符数组的方法,字符数组后面会详细讲解,这里先了解一下 当数组元素个数为变量时,

  • Go 语言的指针的学习笔记

    Go 的原生数据类型可以分为基本类型和高级类型,基本类型主要包含 string, bool, int 及 float 系列,高级类型包含 struct,array/slice,map,chan, func . 相比 Java,Python,Javascript 等引用类型的语言,Golang 拥有类似C语言的指针这个相对古老的特性.但不同于 C 语言,Golang 的指针是单独的类型,而不是 C 语言中的 int 类型,而且也不能对指针做整数运算.从这一点看,Golang 的指针基本就是一种引用

  • json 入门学习笔记 示例代码

    Json介绍: JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.易于人阅读和编写.      json 官方网站 http://www.json.org/      json.net 下载地址 http://json.codeplex.com/releases/view/37810 Demo: 描述: 点击获取按钮后,将请求页面,获取json数据,填充到表格html代码: 复制代码 代码如下: <!DOCTYPE html PUBLIC "-/

  • 值得收藏的asp.net基础学习笔记

    值得收藏的asp.net基础学习笔记,分享给大家. 1.概论 浏览器-服务器 B/S 浏览的 浏览器和服务器之间的交互,形成上网B/S模式 对于HTML传到服务器  交给服务器软件(IIS)  服务器软件直接读取静态页面代码,然后返回浏览器 对于ASPX传达服务器  交给服务器软件(IIS)   IIS发现自己处理不了aspx的文件,就去映射表根据后缀名里找到响应的处理程序(isapi,服务器扩展程序) 问题:IIS如何调用可扩展程序? 答:可扩展程序首先就是按照IIS提供的借口实现代码,所以I

  • 从ThinkPHP3.2.3过渡到ThinkPHP5.0学习笔记图文详解

    本文实例讲述了从ThinkPHP3.2.3过渡到ThinkPHP5.0学习笔记.分享给大家供大家参考,具体如下: 用tp3.2.3做了不少项目,但是毕竟要与时代接轨,学习一些新的框架,比如tp5 以下记录一些学习中遇到的问题及解决办法,还有tp3.2和tp5.0的一些区别,适合给用过tp3没用过tp5的童鞋做个参考. 随着学习不断更新...... +++++++++++++++++++++++分割线总是要有的+++++++++++++++++++++++ 首先到tp官网下载了一个最新的Think

随机推荐