亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C語(yǔ)言實(shí)現(xiàn)個(gè)人財(cái)務(wù)管理

 更新時(shí)間:2021年11月22日 17:25:16   作者:小仙女ya  
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)個(gè)人財(cái)務(wù)管理,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了C語(yǔ)言實(shí)現(xiàn)個(gè)人財(cái)務(wù)管理的具體代碼,供大家參考,具體內(nèi)容如下

該程序可以完成個(gè)人財(cái)務(wù)管理。每個(gè)人的財(cái)務(wù)項(xiàng)目應(yīng)當(dāng)包括姓名、年度、收入、支出等。為了敘述簡(jiǎn)單,以一個(gè)財(cái)政年度為統(tǒng)計(jì)單位,程序中可以計(jì)算每個(gè)人的每個(gè)財(cái)政年度的收入總額、支出總額、存款總額等,并能夠打印出來(lái)。需要注意的是,收入總額不可能只輸入一次,而可能是多次收入的和;同樣地,支出總額也不可能只是一次支出,應(yīng)是多次支出的總和。

【設(shè)計(jì)思想】本程序是一個(gè)財(cái)務(wù)管理程序,涉及收入和支出,雖然是個(gè)人財(cái)務(wù)管理程序,但最好能夠按照一種標(biāo)準(zhǔn)的財(cái)務(wù)管理軟件來(lái)考慮,所以在程序設(shè)計(jì)時(shí);需要考慮如下幾個(gè)因素:
每一筆收入或支出都可以理解為一筆交易,那么程序最多可以容納多少筆交易決定數(shù)組的元素個(gè)數(shù),必須有一個(gè)預(yù)測(cè),不妨先假定為50筆。
確定結(jié)構(gòu)體形式時(shí)需要認(rèn)真考慮,它關(guān)系到程序?qū)崿F(xiàn)的思路和方式。一個(gè)人的收入和支出顯然是多次輸入的,而每一筆交易必須記錄交易的日期和姓名,所以結(jié)構(gòu)體應(yīng)包含日期和姓名信息。從銀行存款單我們可以知道,每一次存款和取款的數(shù)目必須記錄,而且是分別記錄,所以結(jié)構(gòu)體考慮增加收入和支出兩個(gè)元素,這樣就形成了如下描述每一筆交易的結(jié)構(gòu)體。

代碼:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define SIZE 50

struct Date{
    int year,month,day;
};
struct deal{
    struct Date date;
    char name[12];
    double earning;
    double payout;
};
void Menu();
void InputOneDeal(struct deal *per);
void PrintOneDeal(struct deal *per);
void SortPerson(struct deal *per,struct deal **per_sort);

int main()
{
    struct deal person[SIZE]={0};
    char key;
    int i=0;
    while(1){
        Menu();
        key=getche();
        printf("\n");
        switch(key)
        {
        case '1':
            InputOneDeal(person+i);
            i++;
            break;
        case '2':
            PrintOneDeal(person);
            break;
        case '3':
            exit(0);
        default:break;
        }
    }
    return 0;
}
void Menu()
{
    printf("1.Input one deal\n");
    printf("2.Print one year balance\n");
    printf("3.Exit\n");
    printf("Please select(1-3):");
}
void InputOneDeal(struct deal *per)
{
    char s[10];
    printf("Date(YYYY-MM-DD):");
    scanf("%d-%d-%d",&per->date.year,&per->date.month,&per->date.day);
    printf("name:");
    scanf("%9s",s);
    printf("deal(+/-):");
    scanf("%9s",s);
    if(s[0]=='-')
        per->payout=atof(s);
    else
        per->earning=atof(s);
}
void PrintOneDeal(struct deal *per)
{
    struct deal *per_sort[SIZE]={NULL};
    int i, year, tag;
    char name[12];
    double earning, payout;
    SortPerson(per,per_sort) ;
    printf ("Name------Year--——-Earning----Payout----Balance\n" ) ;i =- 0;
    while(per_sort[i]!= NULL)
    {
        strcpy (name, per_sort[i]->name);
        printf ("%-12s ", name) ;
        tag = 1;
        while(per_sort[i]!= NULL && strcmp(name,per_sort[i]->name)==0)
        {
            year = per_sort[i]->date.year;
            earning = 0;
            payout = 0 ;
            while(per_sort[i]!= NULL && strcmp(name, per_sort[i]->name)==0 && year == per_sort[i]->date.year)
            {
                earning+=per_sort[i]->earning;
                payout+= per_sort[i]->payout;
                i++;
            }
            if (tag==1)
            {
                printf ("%-6d %11.2lf %11.2lf %11.2lf\n" , year,earning,payout,earning+payout) ;
                tag = 0 ;
            }
            else
                printf ("%12s %-6d %11.21f %11.21f %1.2lf\n", " ",year, earning, payout, earning + payout);

        }
    }
}
void SortPerson(struct deal *per,struct deal **per_sort)
{
    int i, j, k;
    struct deal *t;
    i = 0;
    while((per+i)->date.year !=0)
    {
        per_sort[i] = per + i;
        i++;
    }
    for(i = 0; per_sort[i] != NULL; i++)
    {
            k = i;
            for(j = i+1;per_sort[j]!=NULL;j++)
                if(strcmp(per_sort[j]->name,per_sort[k]->name)<0||strcmp(per_sort[j]->name, per_sort[k]->name)==0 &&per_sort[j]->date.year < per_sort[k]->date.year)
                    k=j;
            if(k != i)
            {
                t = per_sort [i] ;
                per_sort[i] = per_sort [k];
                per_sort[k] = t;
            }
    }
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 深入C++中API的問題詳解

    深入C++中API的問題詳解

    本篇文章是對(duì)C++中API的問題進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C++實(shí)現(xiàn)班級(jí)成績(jī)管理系統(tǒng)

    C++實(shí)現(xiàn)班級(jí)成績(jī)管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)班級(jí)成績(jī)管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • C語(yǔ)言線性表中順序表超詳細(xì)理解

    C語(yǔ)言線性表中順序表超詳細(xì)理解

    程序中經(jīng)常需要將一組數(shù)據(jù)元素作為整體管理和使用,需要?jiǎng)?chuàng)建這種元素組,用變量記錄它們,傳進(jìn)傳出函數(shù)等。一組數(shù)據(jù)中包含的元素個(gè)數(shù)可能發(fā)生變化,順序表則是將元素順序地存放在一塊連續(xù)的存儲(chǔ)區(qū)里,元素間的順序關(guān)系由它們的存儲(chǔ)順序自然表示
    2022-03-03
  • 淺談C語(yǔ)言的變量和常量

    淺談C語(yǔ)言的變量和常量

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言的變量和常量,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-02-02
  • C語(yǔ)言中注釋與注意事項(xiàng)的深入講解

    C語(yǔ)言中注釋與注意事項(xiàng)的深入講解

    在編寫C語(yǔ)言源代碼時(shí),應(yīng)該多使用注釋,這樣有助于對(duì)代碼的理解,這篇文章主要給大家介紹了關(guān)于C語(yǔ)言中注釋與注意事項(xiàng)的相關(guān)資料,需要的朋友可以參考下
    2021-09-09
  • C語(yǔ)言之通訊錄的模擬實(shí)現(xiàn)代碼

    C語(yǔ)言之通訊錄的模擬實(shí)現(xiàn)代碼

    這篇文章主要介紹了C語(yǔ)言之通訊錄的模擬實(shí)現(xiàn)代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • C語(yǔ)言中結(jié)構(gòu)體與內(nèi)存對(duì)齊實(shí)例解析

    C語(yǔ)言中結(jié)構(gòu)體與內(nèi)存對(duì)齊實(shí)例解析

    C語(yǔ)言結(jié)構(gòu)體對(duì)齊也是老生常談的話題了,基本上是面試題的必考題,這篇文章主要給大家介紹了關(guān)于C語(yǔ)言中結(jié)構(gòu)體與內(nèi)存對(duì)齊的相關(guān)資料,需要的朋友可以參考下
    2021-07-07
  • 徹底掌握C語(yǔ)言strcat函數(shù)的用法

    徹底掌握C語(yǔ)言strcat函數(shù)的用法

    strcat是用來(lái)拼接字符串的,它會(huì)將參數(shù)?src?字符串復(fù)制到參數(shù)?dest?所指的字符串尾部,本章帶你了解它的使用并模擬實(shí)現(xiàn)它
    2022-05-05
  • C語(yǔ)言中 值傳遞和指針傳遞實(shí)例詳解

    C語(yǔ)言中 值傳遞和指針傳遞實(shí)例詳解

    這篇文章主要介紹了C語(yǔ)言中 值傳遞和指針傳遞實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • C++實(shí)現(xiàn)動(dòng)態(tài)分配const對(duì)象實(shí)例

    C++實(shí)現(xiàn)動(dòng)態(tài)分配const對(duì)象實(shí)例

    這篇文章主要介紹了C++實(shí)現(xiàn)動(dòng)態(tài)分配const對(duì)象實(shí)例,包括了const對(duì)象的創(chuàng)建、刪除及應(yīng)用實(shí)例,需要的朋友可以參考下
    2014-10-10

最新評(píng)論