ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

华中科技大学SPOC编程题第六章

2021-01-02 18:31:38  阅读:291  来源: 互联网

标签:include ISBN int 华中科技大学 编程 char num SPOC data


1图书 ISBN 号码中识别码的计算(35分)
题目内容:

  给出一个不包含识别码的 ISBN 号码(前 11 位),计算其识别码,并输出完整的 ISBN 号码。

  每一本正式出版的图书都有一个 ISBN 号码与之对应,ISBN 码包括 9 位数字、1 位识别码和 3 位分隔符,其规定格式如:“x-xxx-xxxxx-x”,其中符号“-”就是分隔符(键盘上的减号),最后一位是识别码,例如“0-670-82162-4”就是一个标准的 ISBN 码。

  ISBN 码的首位数字表示书籍的出版语言,例如,符号“0”代表英语;第一个分隔符“-”之后的三位数字代表出版社,第二个分隔符后的五位数字“82162”代表该书在该出版社的编号;最后一位识别码的计算方法:

  1、第 1 位数字乘以 1,加上第 2 位数字乘以 2,再加上第 3 位数字乘以 3,……,以此类推;

  2、再把所得结果对 11 求余,所得的余数即为识别码,如果余数为 10,则识别码为大写字母 X

代码:(编写函数ISBN,完善以下代码)

#include

#include

using namespace std;

int main()

{

char charISBN11[12], *charISBN;

cin>>charISBN11;

charISBN=ISBN(charISBN11);

cout<<charISBN<<endl;

delete charISBN;

return 0;

}

输入格式:

图书的 ISBN 号码(前 11 位)

输出格式:

完整的图书的 ISBN 号码(13 位)

输入样例:

0-670-82162

输出样例:

0-670-82162-4

时间限制:500ms内存限制:32000kb


这个是我室友伟哥做的,我看着他做,啪啪啪,很快啊,他就操起来了,也就那么几秒钟,他就提着这包代码出来了。。。
这就是编程的可怕吗,明明写得差不多,为什么我的不行。。。


这是伟哥qq 1596892709,
xdm可以咨询咨询怎么几秒钟解决问题的


#include <iostream>

#include <cstring>

using namespace std;
char z[14] = { 0 };
char* ISBN(char* x)
{
    int num = 0;
    char y[12] = { 0 };
    for (int i = 0; i <= 11; i++)
    {
        if (x[i] >= '0' && x[i] <= '9')
        {
            y[num] = x[i];
            num++;
        }
    }
    int goal = 0;
    for (int i = 0; i <= 8; i++)
    {
        goal += (i + 1) * (y[i]-'0');
        goal %= 11;
    }
    char goal0 = goal + '0';
    for (int i = 0; i <= 10; i++)
    {
        z[i] = x[i];
    }
    z[11] = '-';
    if (goal == 10)
    {
        z[12] = 'X';
    }
    else
        z[12] = goal0;
    z[13] = '\0';
    return z;
    
}
int main()
{
    char charISBN11[12], * charISBN;
    cin >> charISBN11;
    charISBN = ISBN(charISBN11);
    cout << charISBN << endl;
    return 0;
}

2最长单词(35分)
题目内容:

求字符串单词最长的一个单词(如果有多个最长单词,以最左边的为准),并输出该单词。

代码:(编写函数fun,完善以下代码)

#include

using namespace std;

int main()

{

 char c1[100];

 char c2[100];

 cin.getline(c1,100);

 fun(c1,c2);

 cout<<c2<<endl;

 return 0;

}

输入格式:

一条英文句子

输出格式:

英文句子中的最长单词

输入样例:

A Grain of Sand William Blake

输出样例:

William

时间限制:500ms内存限制:32000kb

#include<iostream>
#include<cstring>
using namespace std;
void fun(char c1[],char c2[])
{int len1=0,len2=0,pl=0;
for(int i=0;i<strlen(c1);i++)
{

if(c1[i]==' '||c1[i]=='\0')
len1=0;
else len1++;
if(len1>len2) {len2=len1;pl=i-len2+1;}
}int j=0;
for(int i=pl;i<pl+len2;i++)
c2[j++]=c1[i];
c2[j]='\0';
}
int main()

{

     char c1[100];

     char c2[100];

     cin.getline(c1,100);

     fun(c1,c2);

     cout<<c2<<endl;

     return 0;

}

3数据的有序插入(30分)
题目内容:

   插入一个数据到一个有序的一维数组中,要求插入后,该数组任然保持原有顺序。

代码:

#include

using namespace std;

int main()

{

int data[11]={12,34,56,78,90,167,258,389,945,1890};

int num;

cin>>num;

FunSort(data,10,num);

int i;

cout<<data[0];

for(i=1;i<11;i++)

    cout<<" "<<data[i];

cout<<endl;

return 0;

}

输入格式:

一个整数

输出格式:

数据插入完成后,输出数组所保存的所有数据,数据之间用一个空格分隔。

输入样例:

57

输出样例:

12 34 56 57 78 90 167 258 389 945 1890

时间限制:500ms内存限制:32000kb

#include<iostream>
using namespace std;
void FunSort(int data[],int n,int num)
{
for(int i=n;i>0;i--)
{if(num>data[i-1]) {data[i]=num;break;}
else data[i]=data[i-1];
}
while(data[1]==data[0])
data[0]=num;
}
int main()

{

    int data[11]={12,34,56,78,90,167,258,389,945,1890};

    int num;

    cin>>num;

    FunSort(data,10,num);

    int i;

    cout<<data[0];

    for(i=1;i<11;i++)

        cout<<" "<<data[i];

    cout<<endl;

    return 0;

}

//下面这个是我第一次写的,结果运行时例一运行超时了。。。

void FunSort(int data[], int n, int num)
{
	int flag = 1;
	for (int i = n; i > 0; i--)
		{ if (num > data[i - 1]) { data[i] = num; flag = 0; break; }
		else data[i] = data[i - 1];
		}
		while (flag)
			data[0] = num;
}

明天考中国语文,
所以今晚游戏吧。
在这里插入图片描述

标签:include,ISBN,int,华中科技大学,编程,char,num,SPOC,data
来源: https://blog.csdn.net/weixin_51236357/article/details/112093056

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有